jQuery Ajax Post 回调函数不执行问题的解决方法
今天在写一个检查用户名的功能时,使用的是jQuery.post(url,[data],[callback],[type])这个函数,但是发现其中的回调函数不能执行。
先来看看我的代码:
前台代码:
<scripttype="text/javascript"> functioncheckUser(){ varuser=$('#<%=txtUser.ClientID%>').val(); $.post('checkUser.ashx',{Action:"Check",Name:user}, function(data){ alert(data); }, "json"); } </script>
后台代码(checkUser.ashx):
publicvoidProcessRequest(HttpContextcontext) { context.Response.ContentType="application/json"; stringaction=context.Request["Action"]; stringuser=context.Request["Name"]; stringresult="{result:0}"; switch(action) { case"Check": if(us.isExists(user)) { result="{result:1}"; } break; } context.Response.Write(result); }
但是怎么也不执行回调函数中的alert(data)语句,经过单步跟踪,最后发现是返回的Json字符串有问题。
原来jquery中规定返回的JSON字符串的KEY要用引号括起来,如{"result":1}这样才可以。
下面再看下jqueryAjax不执行回调函数success的原因
jqueryAjax不执行回调函数success的原因:
$.ajax({ type:"post", contentType:"application/json", url:basePath+"pages/Tongji/disposeAgree.action?cepingitem="+cepingitem+"&userrelation="+userrelation, //data:{fenshu:8}, dataType:"json", success:function(result){ alert("操作成功"); }, error:function(response){ alert("error"); } });
如上,因为设置了属性dataType:"json",故如果后台返回的不是正确的JSON字符串,那么永远不执行回调函数success,而只执行error函数。要么返回正确的JSON字符串,要么把dataType属性改为text
正确的返回JSON字符串如下:
pw.write("{\"name\":\"zs\"}"); pw.write("{\"name\":"+true+"}");
错误的例子:
pw.write("{‘name':‘zs'}");
以上所述是小编给大家介绍的jQueryAjaxPost回调函数不执行问题的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!