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);

  

ajax处理json数据,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。