一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

jquery ajax 同步異步的執行示例代碼

大家先看一段簡單的jquery ajax 返回值的js
代碼
復制代碼 代碼如下:
function getReturnAjax{
$.ajax({
type:"POST",
http://www.jb51.NET/userexist.ASPx",
data:"username="+vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"<img src='images/ok.gif'/><b><font color='#ffff00'>該用戶名可以使用</font></b>",false)
return true;
}
else
{
showtipex(vusername.id,"<img src='images/cancel.gif'/><b><font color='#ffff00'>該用戶已被注冊</font></b>",false);
vusername.className="bigwrong";
return false;
}
}
});
}

但是我們調用這個getReturnAjax()發現始終取得的都是false,那就是說return true,return false根本沒有起作用,在火狐下用firebug調試也證明,代碼根本不會執行到return 部分。

我們試想在函數里先定義一個變量,然后在ajax里賦值,最后在函數的末尾返回這個變量,會不會有效果呢?我們把代碼修改如下:
代碼
復制代碼 代碼如下:
function getAjaxReturn()
{
var bol=false;
$.ajax({
type:"POST",
http://www.jb51.NET/userexist.ASPx",
data:"username="+vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"<img src='images/ok.gif'/><b><font color='#ffff00'>該用戶名可以使用</font></b>",false)
// return true;
bol=true;
}
else
{
showtipex(vusername.id,"<img src='images/cancel.gif'/><b><font color='#ffff00'>該用戶已被注冊</font></b>",false);
vusername.className="bigwrong";
//return false;
}
}
});
return bol;
}

結果仍然不起作用。最后解決方案有2,如下

1、添加async:false.即修改為同步了,什么意思?(按同事解釋就是,這是等這個ajax有了返回值后才會執行下面的js。一語道破天機,怪不得以前很多ajax調用里面的賦值都不起作用)。這樣等ajax給bol賦值完畢后,才執行下面的js部分。而剛剛異步的話,還沒有來得及賦值,就已經return了。


代碼
復制代碼 代碼如下:
function getAjaxReturn()
{
var bol=false;
$.ajax({
type:"POST",
async:false,
http://www.jb51.NET/userexist.ASPx",
data:"username="+vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"<img src='images/ok.gif'/><b><font color='#ffff00'>該用戶名可以使用</font></b>",false)
// return true;
bol=true;
}
else
{
showtipex(vusername.id,"<img src='images/cancel.gif'/><b><font color='#ffff00'>該用戶已被注冊</font></b>",false);
vusername.className="bigwrong";
//return false;
}
}
});
return bol;
}

2、 通過傳入一個函數解決這個問題。

代碼
復制代碼 代碼如下:
function getAjaxReturn(success_function,fail_function)
{
var bol=false;
$.ajax({
type:"POST",
http://www.jb51.NET/userexist.ASPx",
data:"username="+vusername.value,
success:function(msg){
if(msg=="ok"){
showtipex(vusername.id,"<img src='images/ok.gif'/><b><font color='#ffff00'>該用戶名可以使用</font></b>",false)
success_function(msg);
}
else
{
showtipex(vusername.id,"<img src='images/cancel.gif'/><b><font color='#ffff00'>該用戶已被注冊</font></b>",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);
}

JavaScript技術jquery ajax 同步異步的執行示例代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 噜噜噜 综合 亚洲 | 影院成人区精品一区二区婷婷丽春院影视 | 青青草99久久精品国产综合 | 91po国产在线高清福利 | 日本伊人网 | 亚洲视频一区二区 | 日韩中文字幕免费观看 | 国产a v高清一区二区三区 | 久久伊人色综合 | 小泽玛利亚一区二区三区免费 | 亚洲妇人成熟性成熟美女 | 狠狠色噜噜狠狠狠狠米奇7777 | 五月综合激情视频在线观看 | 亚洲一区二区三区深夜天堂 | 国内精品哆啪啪 | 亚洲欧洲国产经精品香蕉网 | 日韩免费视频播放 | 香蕉久久精品国产 | 大陆老头xxxxxhd | 小视频免费在线观看 | 97人人模人人爽人人喊6 | 欧美视频久久久 | 国产对白在线播放九色 | 女子十八毛片 | 婷婷色视频 | 久久精品国产99久久无毒不卡 | 色婷婷一区二区三区四区成人 | 欧美福利第一页 | 亚洲视频区 | 福利网在线观看 | 黄色视屏在线免费观看 | 国产男女视频在线观看 | 久久97久久97精品免视看清纯 | 欧美黑人巨大 | 亚洲精品高清国产一久久 | 2021国产成人午夜精品 | 国产一区二区三区毛片 | 亚洲合集综合久久性色 | 综合在线视频 | 久久精品视频播放 | 正在播放国产乱子伦视频 |