ajax处理json数据
在php生成json数据(json_decode())
参数为索引数组生成的数据格式为js数组
$fruit = array(‘apple‘,‘banana‘,‘pear‘,‘orange‘); $fruit_jn = json_encode($fruit); //[‘apple‘,‘banana‘,‘pear‘,‘orange‘]
参数为关联数组生成的数据是json对象格式
$fruit = array(‘a‘=>‘apple‘,‘b‘=>‘banana‘,‘c‘=>‘pear‘,‘d‘=>‘orange‘); $fruit_jn = json_encode($fruit);//{"a":"apple","b":"banana","c":"pear","d":"orange"}
参数为对象生成的数据也是json对象格式,会忽略对象的方法
$animal = array(‘a‘=>array(‘aa‘=>‘cat‘,‘bb‘=>‘pig‘),"c"=>array("cc"=>‘chicken‘,"dd"=>‘duck‘)); echo json_encode($animal); //{"a":{"aa":"cat","bb":"pig"},"c":{"cc":"chicken","dd":"duck"}}
处理json数据
var info = xhr.responseText;
此时实际上json对象只是一个字符串,因为json对象是作为字符串返回的,所以我们并不能很方便的处理,那么我们如何把转为实实在在的js对象呢?这里我们要用到eval()函数。
eval(‘var info = ‘+info);
现在info就是实实在在的json对象了,那么我们可以很轻松的将数据显示在想要的部分。
var xhr = function(){ var xhr = null; if(window.XMLHttpRequest) { xhr = new XMLHttpRequest(); } else if(window.ActiveXObject) { xhr = new ActiveXObject(‘Microsoft.XMLHTTP‘); } return xhr; } xhr.onreadystatechange = function(){ if(xhr.readyState==4 && xhr.status==200){ var info = xhr.responseText; //info是以字符串形式给我们返回string——‘{"name":"apple5s","price":"4999","number":"24","weight":"105"}‘ //eval(‘var a= {"name":"apple5s","price":"4999"}‘); eval("var info_jn="+info); //让info字符串内容当作表达式运行 var rst = document.getElementById(‘result‘); rst.innerHTML += "名字:"+info_jn.name; rst.innerHTML += " 价格:"+info_jn.price; rst.innerHTML += " 重量:"+info_jn.weight; rst.innerHTML += " 数量:"+info_jn.number; } } xhr.open("get",‘./02.php‘); xhr.send(null);
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。