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回调函数不执行问题的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!