Let’s first look at a simple js ajax return value of jquery
code
function getReturnAjax{
$.ajax({
type:"POST",
http://www.cnblogs.com/wlmemail/admin/"ajax/userexist.aspx",
data:"username=" vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"
This username can use",false)
return true;
}
else
{
showtipex(vusername.id,"
The user has been registered",false);
vusername.className="bigwrong";
return false;
}
}
});
}
But when we call getReturnAjax(), we find that all we get is false. That is to say, return true and return false have no effect at all. Use firebug to debug under Firefox. It also proves that the code will not execute to the return part at all.
Let’s imagine defining a variable in the function, then assigning it in ajax, and finally returning the variable at the end of the function. Will it be effective? We modify the code as follows:
Code
function getAjaxReturn()
{
var bol= false;
$.ajax({
type:"POST",
http://www.cnblogs.com/wlmemail/admin/"ajax/userexist.aspx",
data:" username=" vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"
This username can use",false)
// return true;
bol=true;
}
else
{
showtipex(vusername.id,"
The user has been registered",false);
vusername.className="bigwrong";
//return false;
}
}
});
return bol;
}
The result still doesn't work. The final solution is 2, as follows
1. Add async:false. That is, change it to synchronization. What does it mean? (According to a colleague’s explanation, the following js will not be executed until the ajax has a return value. This makes it clear, no wonder the assignments in many ajax calls in the past did not work). In this way, after ajax has assigned the value to bol, the following js part will be executed. If it was asynchronous just now, it would have been returned before the value could be assigned.
Code
function getAjaxReturn()
{
var bol=false;
$.ajax({
type:"POST",
async:false,
http://www.cnblogs.com/wlmemail/admin/" ajax/userexist.aspx",
data:"username=" vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername. id,"
This username can use", false)
// return true;
bol=true;
}
else
{
showtipex(vusername.id,"
The user has been registered",false);
vusername.className="bigwrong";
//return false;
}
}
});
return bol;
}
2. Solve this by passing in a function question.
Code
function getAjaxReturn(success_function,fail_function)
{
var bol=false;
$.ajax({
type:"POST",
http://www.cnblogs.com/wlmemail/admin/"ajax/userexist.aspx",
data:"username=" vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"
该用户名可以使用",false)
success_function(msg);
}
else
{
showtipex(vusername.id,"
该用户已被注册",false);
vusername.className="bigwrong";
fail_function(msg);
//return false;
}
}
});
function success_function(info)
{
//do what you want do
alert(info);
}
funciont fail_function(info)
{
//do what you want do
alert(info);
}