jquery ajax內(nèi)賦值不起作用
作者:佚名 時(shí)間:2012-08-04 分享到:
1、添加async:false.即修改為同步了,什么意思?(等這個(gè)ajax有了返回值后才會(huì)執(zhí)行下面的js。一語(yǔ)道破天機(jī),怪不得以前很多ajax調(diào)用里面的賦值都不起作用)。這樣等ajax給bol賦值完畢后,才執(zhí)行下面的js部分。而剛剛異步的話,還沒(méi)有來(lái)得及賦值,就已經(jīng)return了。
代碼
復(fù)制代碼 代碼如下:
function getAjaxReturn()
{
var bol=false;
$.ajax({
type:"POST",
async:false,
http://www.ktcbnqb.cn/",
data:"username="+vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"該用戶名可以使用",false)
// return true;
bol=true;
}
else
{
showtipex(vusername.id,"該用戶已被注冊(cè)",false);
vusername.className="bigwrong";
//return false;
}
}
});
return bol;
}
2、 通過(guò)傳入一個(gè)函數(shù)解決這個(gè)問(wèn)題。
代碼
復(fù)制代碼 代碼如下:
function getAjaxReturn(success_function,fail_function)
{
var bol=false;
$.ajax({
type:"POST",
http://www.ktcbnqb.cn/",
data:"username="+vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"該用戶名可以使用",false)
success_function(msg);
}
else
{
showtipex(vusername.id,"該用戶已被注冊(cè)",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);
}