- $.ajax({
- type :"post",
- url :"busine_in.action",
- timeout : 40000,
- data: "centerid="+s,
- error : function(XMLHttpRequest, textStatus, errorThrown) {
- alert(XMLHttpRequest.status);
- alert(XMLHttpRequest.readyState);
- alert(textStatus);
- alert('读取超时,请检查网络连接');
- },
- dataType : "json",
- success : function(data){
- alert("1");
- $("#select_div").hide();
- str='<div style=" overflow:auto;height:430px;">';
- str+='<table border="0" cellspacing="0" cellpadding="0" width="100%" class="table2 muma_list">';
- str+='<tr>';
- str+='<th align="left">区域</th>';
- str+='</tr>';
- $.each(data,function(i, n){
- alert("2");alert(i);alert("n=="+n.length);
- if ("list" == i){
- str+='<tr>';
- str+='<td><a href="javascript:unitedit(\''+n.areaId+'\')" title="点击编辑">'+n.areaName+'</a></td>';
- str+='</tr>';
- }
- });
- str+='</table>';
- str+='</div>';
- alert("3");
- $("#select_div").html(str);
- }
- });
上述的代码一直进入error,并且弹出的一直是parsererror
- alert(XMLHttpRequest.status);
弹出200正常
- alert(XMLHttpRequest.readyState);
弹出4正常
最后发现弹出parsererror的原因是类型的问题,也就是说可能是返回类型出问题了。果然进过查找,发现在struts.xml文件中的ajax请求的action中的result返回类型不是json
来自 http://blog.csdn.net/enterys/article/details/7646295
jQuery的ajax,dataType=json ,后台返回的json格式正确 但总是进到error里面,经查找原因后,JQuery1.4 以后,返回的json格式必须是标准的格式,像{a:"a"} 这种是错误的必须是{"a":"a"}
当遇到以上问题时,根本上当然是从返回的数据入手,将返回数据书写成标准的json。
当然,如果后端不能及时返回标准json而我们 又急用的时候可以将dataType设置为text字符串,然后在本地将字符串转化为json,下面介绍3在种转化方式。
1、var json = eval('('+result+')');
2、var json = (new Function('return ' + result))();