溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ajax中如何讀取Json數(shù)據(jù)

發(fā)布時(shí)間:2021-08-10 17:04:19 來(lái)源:億速云 閱讀:142 作者:Leah 欄目:web開(kāi)發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)ajax中如何讀取Json數(shù)據(jù),文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

一、基礎(chǔ)知識(shí)

什么是json?

JSON 指的是 JavaScript 對(duì)象表示法(JavaScript Object Notation)
JSON 是輕量級(jí)的文本數(shù)據(jù)交換格式
JSON 獨(dú)立于語(yǔ)言 *
JSON 具有自我描述性,更易理解
JSON 使用 JavaScript 語(yǔ)法來(lái)描述數(shù)據(jù)對(duì)象,但是 JSON 仍然獨(dú)立于語(yǔ)言和平臺(tái)。JSON 解析器和 JSON 庫(kù)支持許多不同的編程語(yǔ)言。
JSON - 轉(zhuǎn)換為 JavaScript 對(duì)象

JSON 文本格式在語(yǔ)法上與創(chuàng)建 JavaScript 對(duì)象的代碼相同。

      由于這種相似性,無(wú)需解析器,JavaScript 程序能夠使用內(nèi)建的 eval() 函數(shù),用 JSON 數(shù)據(jù)來(lái)生成原生的 JavaScript 對(duì)象。

二、讀取Json中的數(shù)據(jù)

首先我編寫了一個(gè)Json的文件,里面有內(nèi)容。注意格式。

ajax中如何讀取Json數(shù)據(jù)

 圖一  編寫json的文件

然后,編寫html代碼,并引用ajax。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>使用AJAX異步讀取json</title>
<script src="ajax.js">
</script>
<script>
  window.onload=function()
  {
    /*獲得按鈕*/
    var aBtn=document.getElementById('btn1');
    //給按鈕添加點(diǎn)擊事件
    aBtn.onclick=function()
    {
      //調(diào)用ajax函數(shù)
      ajax('data.json',function(str){
        //將JSON 數(shù)據(jù)來(lái)生成原生的 JavaScript 對(duì)象
        var arr=eval(str);
        alert(arr[0].b);
    });
    };
  };
</script>
</head>
<body>
讀取json里面的數(shù)據(jù) <br />
<input id="btn1" type="button" value="讀取json里面的數(shù)據(jù)" />
</body>
</html>

封裝的AJAX函數(shù)代碼如下:

/*
AJAX封裝函數(shù)
url:系統(tǒng)要讀取文件的地址
fnSucc:一個(gè)函數(shù),文件取過(guò)來(lái),加載完會(huì)調(diào)用
*/
function ajax(url, fnSucc, fnFaild)
{
  //1.創(chuàng)建Ajax對(duì)象
  var oAjax=null;

  if(window.XMLHttpRequest)
  {
    oAjax=new XMLHttpRequest();
  }
  else
  {
    oAjax=new ActiveXObject("Microsoft.XMLHTTP");
  }

  //2.連接服務(wù)器
  oAjax.open('GET', url, true);

  //3.發(fā)送請(qǐng)求
  oAjax.send();

  //4.接收服務(wù)器的返回
  oAjax.onreadystatechange=function ()
  {
    if(oAjax.readyState==4) //完成
    {
      if(oAjax.status==200)  //成功
      {
        fnSucc(oAjax.responseText);
      }
      else
      {
        if(fnFaild)
          fnFaild(oAjax.status);
      }
    }
  };
}

      接下來(lái)就是要讀取出文件內(nèi)容,在這之前,有一點(diǎn)要提的是,AJAX是從服務(wù)器上讀取文件,所以要把寫好的JSON文件放到服務(wù)器的路徑下,可能初學(xué)者接觸過(guò)的服務(wù)器只有IIS,他的文件路徑是C:\inetpub\wwwroot\aspnet_client\system_web,只要把Json放到這個(gè)路徑下,然后用localhost來(lái)訪問(wèn)服務(wù)器,就可以了。

ajax中如何讀取Json數(shù)據(jù)

關(guān)于ajax中如何讀取Json數(shù)據(jù)就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI