如何使用原生ajax處理json字符串-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)如何使用原生ajax處理json字符串,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)長(zhǎng)期為上千余家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為北關(guān)企業(yè)提供專業(yè)的網(wǎng)站建設(shè)、網(wǎng)站制作,北關(guān)網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。

AJAX


AJAX = Asynchronous JavaScript and XML(異步的 JavaScript 和 XML)。


AJAX 不是新的編程語(yǔ)言,而是一種使用現(xiàn)有標(biāo)準(zhǔn)的新方法。


AJAX 是與服務(wù)器交換數(shù)據(jù)并更新部分網(wǎng)頁(yè)的藝術(shù),在不重新加載整個(gè)頁(yè)面的情況下。

什么是json?

JSON的全稱是 Javascript Object Notation(javascript對(duì)象表示法),是基于javascript對(duì)象字面量,如果單從眼睛看,JSON里的數(shù)據(jù)是被保存在花括號(hào)里面-- {},如果在用途上面進(jìn)一步分析,JSON是一種數(shù)據(jù)交換格式。JSON內(nèi)部以 名稱:值這種格式排列,如下面的json1,就是一個(gè)json對(duì)象。

var json1={"name":"李明","age":21,"sex":"boy"}

什么是json字符串?

如其字面意思,給json兩邊加上雙引號(hào)(或者單引號(hào)),為了避免與內(nèi)部的雙引號(hào)沖突,我們這外面放單引號(hào),就成了json字符串了,如下面的json2

var json2='{"name":"李明","age":21,"sex":"boy"}'

2.在我們的數(shù)據(jù)提供頁(yè)面,輸出我們的json,我們還是把數(shù)據(jù)提供頁(yè)面稱為tigong.php    


 代碼如下:

<?php
header("content-type:text/html;charset=utf-8");
echo '{"name":"黎明","age":"12","sex":"男"}';
?>

3.在我們的前端頁(yè)面接收數(shù)據(jù),并且使用eval方法將json字符串解析成為json對(duì)象,用for循環(huán)將它遍歷出來(lái)。我們稱這個(gè)頁(yè)面為testJsonEvel.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <script type="text/javascript">
    window.onload=function(){
      var div1=document.getElementById("div1");
      var bt1=document.getElementById("bt1");
      bt1.onclick=function(){
        //創(chuàng)建ajax對(duì)象,寫(xiě)兼容
        if(window.XMLHttpRequest){
          var xmlHttp=new XMLHttpRequest();
        }else{
          var xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
        };
        //獲取要發(fā)送的數(shù)據(jù),我們這個(gè)例子沒(méi)有
        //設(shè)置發(fā)送數(shù)據(jù)的地址和方法
        xmlHttp.open("POST","tigongjson.php");
        //設(shè)置我們的請(qǐng)求頭信息
        xmlHttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
        //綁定onreadystatechange事件
        xmlHttp.onreadystatechange=function(){
          if(xmlHttp.readyState==4 && xmlHttp.status==200){
            var data=xmlHttp.responseText;
            //json字符串轉(zhuǎn)換成為json對(duì)象
            data=eval("("+data+")");
            var str="";
            str+="姓名:"+data.name+"<br>";
            str+="年齡:"+data.age+"<br>";
            str+="性別:"+data.sex
            div1.innerHTML=str;
          };
        };
        //發(fā)送數(shù)據(jù)
        xmlHttp.send();
      };
    };
  </script>
  <style type="text/css">
    #div1{
      width:200px;
      height:200px;
      background:#f00;
      color:#fff;
    }
    img{
      width:200px;
    }
  </style>
  <title>Document</title>
</head>
<body>
  <div id="div1">
    <img src="../php2/images/1.gif">
  </div>
  <br>
  <button id="bt1">點(diǎn)擊獲取json數(shù)據(jù)</button>
</body>
</html>

evel不存在兼容性問(wèn)題,但是會(huì)有安全漏洞。

效果如圖:

如何使用原生ajax處理json字符串

4.使用JSON.parse方法將json字符串解析稱為json對(duì)象,我們把這個(gè)頁(yè)面稱為testJsonParse.html,代碼如下

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <script type="text/javascript">
    window.onload=function(){
      var div1=document.getElementById("div1");
      var bt1=document.getElementById("bt1");
      bt1.onclick=function(){
        //創(chuàng)建ajax對(duì)象,寫(xiě)兼容
        if(window.XMLHttpRequest){
          var xmlHttp=new XMLHttpRequest();
        }else{
          var xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
        };
        //獲取要發(fā)送的數(shù)據(jù),我們這個(gè)例子沒(méi)有
        //設(shè)置發(fā)送數(shù)據(jù)的地址和方法
        xmlHttp.open("POST","tigongjson.php");
        //設(shè)置我們的請(qǐng)求頭信息
        xmlHttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
        //綁定onreadystatechange事件
        xmlHttp.onreadystatechange=function(){
          if(xmlHttp.readyState==4 && xmlHttp.status==200){
            var data=xmlHttp.responseText;
            //json字符串轉(zhuǎn)換成為json對(duì)象
            data=JSON.parse(data);
            var str="";
            str+="姓名:"+data.name+"<br>";
            str+="年齡:"+data.age+"<br>";
            str+="性別:"+data.sex
            div1.innerHTML=str;
          };
        };
        //發(fā)送數(shù)據(jù)
        xmlHttp.send();
      };
    };
  </script>
  <style type="text/css">
    #div1{
      width:200px;
      height:200px;
      background:#f00;
      color:#fff;
    }
    img{
      width:200px;
    }
  </style>
  <title>Document</title>
</head>
<body>
  <div id="div1">
    <img src="../php2/images/1.gif">
  </div>
  <br>
  <button id="bt1">點(diǎn)擊獲取json數(shù)據(jù)</button>
</body>
</html>

JSON.parse不存在安全漏洞,但是會(huì)有兼容性,IE8及以下不支持。

效果如圖

 如何使用原生ajax處理json字符串

關(guān)于“如何使用原生ajax處理json字符串”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

分享題目:如何使用原生ajax處理json字符串-創(chuàng)新互聯(lián)
新聞來(lái)源:http://muchs.cn/article18/cedcdp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、商城網(wǎng)站、品牌網(wǎng)站設(shè)計(jì)移動(dòng)網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管