詳談Ajax請求中的async:false/true的作用(ajax 在外部調(diào)用問題)
test.html
<a href="javascript:void(0)" rel="external nofollow" onmouseover="testAsync()">
asy.js
function testAsync(){
var temp;
$.ajax({
async: false, //同步請求
type : "GET",
url : 'tet.php',
complete: function(msg){
alert('complete');
},
success : function(data) {
alert('success');
temp=data;
}
});
alert(temp);
}
tet.php
<?php echo "here is html code"; sleep(5); ?>
說明
async: false,(默認(rèn)是true);
如上:false為同步,這個 testAsync()方法中的Ajax請求將整個瀏覽器鎖死,只有tet.php執(zhí)行結(jié)束后,才可以執(zhí)行其它操作。
當(dāng)async: true 時,ajax請求是異步的。
但是其中有個問題:testAsync()中的ajax請求和其后面的操作是異步執(zhí)行的,那么當(dāng)tet.php還未執(zhí)行完,就可能已經(jīng)執(zhí)行了 ajax請求后面的操作,如: alert(temp+' end'); 然而,temp這個數(shù)據(jù)是在ajax請求success后才賦值的,結(jié)果,輸出時會為空。
----------------------------------------------------
由于ajax默認(rèn)為異步調(diào)用,所以很少能直接拿到ajax的返回值。但有時候由于業(yè)務(wù)需要還必須要通過ajax來拿,那么我這里提供兩種方案。
具體方法:
1、就像通過設(shè)置async:false讓其異步變同步;
2、可以將接下來需要使用到的參數(shù)在success之內(nèi)執(zhí)行。
這兩種方案,你根據(jù)你項目的具體實際選擇一個。
使用第一種相對來講,假如你對性能要求不是太大可以選擇。
以上這篇詳談Ajax請求中的async:false/true的作用(ajax 在外部調(diào)用問題)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
artDialog 4.1.5 Dreamweaver代碼提示/補(bǔ)全插件 附下載
artDialog是一個輕巧且高度兼容的javascript對話框組件,可讓你的網(wǎng)頁交互擁有桌面軟件般的用戶體驗2012-07-07
Jquery 跨域訪問 Lightswitch OData Service的方法
修改lightswitch .server project web.config。添加如下內(nèi)容就可以實現(xiàn)對ApplicationData.svc/跨域訪問2013-09-09

