好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

AJAX JSON 实例

AJAX JSON 实例

AJAX 可用来与 JSON 文件进行交互式通信。

AJAX JSON 实例

下面的例子将演示网页如何使用 AJAX 来读取来自 JSON 文件的信息:

function loadXMLDoc() { var xmlhttp; if (window.XMLHttpRequest) { // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码 xmlhttp=new XMLHttpRequest(); } else { // IE6, IE5 浏览器执行代码 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { var myArr = JSON.parse(this.responseText); myFunction(myArr) } } xmlhttp.open("GET","/try/ajax/json_ajax.json",true); xmlhttp.setRequestHeader("Content-Type", "application/json;charset=UTF-8"); xmlhttp.send(); } function myFunction(arr) { var out = ""; var i; for(i = 0; i ' + arr[i].title + '
'; } document.getElementById("demo").innerHTML=out; }

实例


获取课程数据


尝试一下 ?


实例解析 - loadXMLDoc() 函数

当用户点击上面的 "获取课程数据" 这个按钮,就会执行 loadXMLDoc() 函数。

loadXMLDoc() 函数创建 XMLHttpRequest 对象,添加当服务器响应就绪时执行的函数,并将请求发送到服务器。

当服务器响应就绪时,我们就使用 JSON.parse() 方法将数据转换为 JavaScript 对象。:

异步加载 JSON 文档

function loadXMLDoc ( ) { var xmlhttp ; if ( window . XMLHttpRequest ) { // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码 xmlhttp = new XMLHttpRequest ( ) ; } else { // IE6, IE5 浏览器执行代码 xmlhttp = new ActiveXObject ( " Microsoft.XMLHTTP " ) ; } xmlhttp . onreadystatechange = function ( ) { if ( xmlhttp . readyState == 4 && xmlhttp . status == 200 ) { var myArr = JSON . parse ( this . responseText ) ; myFunction ( myArr ) } } xmlhttp . open ( " GET " , " /try/ajax/json_ajax.json " , true ) ; xmlhttp . setRequestHeader ( " Content-Type " , " application/json;charset=UTF-8 " ) ; xmlhttp . send ( ) ; } function myFunction ( arr ) { var out = " " ; var i ; for ( i = 0 ; i < arr . length ; i ++ ) { out += ' <a href=" ' + arr [ i ] . url + ' "> ' + arr [ i ] . title + ' </a><br> ' ; } document . getElementById ( " myDiv " ) . innerHTML = out ; }


AJAX 服务器页面

上面这个例子中使用的服务器页面实际上是一个名为 " json_ajax.json " JSON 文件。

JSON 数据如下:

json_ajax.json 文件:

[ { " title " : " JavaScript 教程 " , " url " : " https://www.hdhcms.com/js/ " } , { " title " : " HTML 教程 " , " url " : " https://www.hdhcms.com/html/ " } , { " title " : " CSS 教程 " , " url " : " https://www.hdhcms.com/css/ " } ]

发送 JSON 数据:

xmlhttp.send(JSON.stringify({ "email": "admin@hdhcms.com", "response": { "name": "hdhcms" } }));

查看更多关于AJAX JSON 实例的详细内容...

  阅读:37次

上一篇

下一篇

第1节:AJAX – onreadystatechange 事件    第2节:AJAX – 向服务器发送    第3节:AJAX XMLHttpRequest 服务器响应    第4节:AJAX JSON 实例    第5节:AJAX XML    第6节:AJAX ASP/PHP    第7节:AJAX 创建 XMLHttpRequest 对象    第8节:AJAX 实例    第9节:AJAX 简介    第10节:AJAX 教程    第11节:AJAX 数据库