本文給大家分享一下,如何使用ajax讀取Json中的數(shù)據(jù)。
一、基礎(chǔ)知識
什么是json?
JSON 指的是 JavaScript 對象表示法(JavaScript Object Notation)
JSON 是輕量級的文本數(shù)據(jù)交換格式
JSON 獨立于語言 *
JSON 具有自我描述性,更易理解
JSON 使用 JavaScript 語法來描述數(shù)據(jù)對象,但是 JSON 仍然獨立于語言和平臺。JSON 解析器和 JSON 庫支持許多不同的編程語言。
JSON - 轉(zhuǎn)換為 JavaScript 對象
JSON 文本格式在語法上與創(chuàng)建 JavaScript 對象的代碼相同。
由于這種相似性,無需解析器,JavaScript 程序能夠使用內(nèi)建的 eval() 函數(shù),用 JSON 數(shù)據(jù)來生成原生的 JavaScript 對象。
二、讀取Json中的數(shù)據(jù)
首先我編寫了一個Json的文件,里面有內(nèi)容。注意格式。

圖一 編寫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');
//給按鈕添加點擊事件
aBtn.onclick=function()
{
//調(diào)用ajax函數(shù)
ajax('data.json',function(str){
//將JSON 數(shù)據(jù)來生成原生的 JavaScript 對象
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:一個函數(shù),文件取過來,加載完會調(diào)用
*/
function ajax(url, fnSucc, fnFaild)
{
//1.創(chuàng)建Ajax對象
var oAjax=null;
if(window.XMLHttpRequest)
{
oAjax=new XMLHttpRequest();
}
else
{
oAjax=new ActiveXObject("Microsoft.XMLHTTP");
}
//2.連接服務(wù)器
oAjax.open('GET', url, true);
//3.發(fā)送請求
oAjax.send();
//4.接收服務(wù)器的返回
oAjax.onreadystatechange=function ()
{
if(oAjax.readyState==4) //完成
{
if(oAjax.status==200) //成功
{
fnSucc(oAjax.responseText);
}
else
{
if(fnFaild)
fnFaild(oAjax.status);
}
}
};
}
接下來就是要讀取出文件內(nèi)容,在這之前,有一點要提的是,AJAX是從服務(wù)器上讀取文件,所以要把寫好的JSON文件放到服務(wù)器的路徑下,可能初學者接觸過的服務(wù)器只有IIS,他的文件路徑是C:\inetpub\wwwroot\aspnet_client\system_web,只要把Json放到這個路徑下,然后用localhost來訪問服務(wù)器,就可以了。

圖二 讀取效果圖
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助。
您可能感興趣的文章:- js讀取json文件片段中的數(shù)據(jù)實例
- 使用MSScriptControl 在 C# 中讀取json數(shù)據(jù)的方法
- Android通過json向MySQL中讀寫數(shù)據(jù)的方法詳解【讀取篇】
- PHP讀取mssql json數(shù)據(jù)中文亂碼的解決辦法
- Android App中讀取XML與JSON格式數(shù)據(jù)的基本方法示例
- js讀取并解析JSON類型數(shù)據(jù)的方法
- Android中Json數(shù)據(jù)讀取與創(chuàng)建的方法
- python讀取json文件并將數(shù)據(jù)插入到mongodb的方法
- asp實現(xiàn)讀取數(shù)據(jù)庫輸出json代碼
- litjson讀取數(shù)據(jù)示例
- javascript 循環(huán)讀取JSON數(shù)據(jù)的代碼
- JSON 數(shù)據(jù)格式詳解