jquery中的ajax同步和異步詳解
之前一直在寫JQUERY代碼的時候遇到AJAX加載數(shù)據(jù)都需要考慮代碼運(yùn)行順序問題。最近的項(xiàng)目用了到AJAX同步。這個同步的意思是當(dāng)JS代碼加載到當(dāng)前AJAX的時候會把頁面里所有的代碼停止加載,頁面出去假死狀態(tài),當(dāng)這個AJAX執(zhí)行完畢后才會繼續(xù)運(yùn)行其他代碼頁面假死狀態(tài)解除。
而異步則這個AJAX代碼運(yùn)行中的時候其他代碼一樣可以運(yùn)行。
jquery的async:false,這個屬性
默認(rèn)是true:異步,false:同步。
$.ajax({ type: "post", url: "path", cache:false, async:false, dataType: ($.browser.msie) ? "text" : "xml", success: function(xmlobj){ } });
有了這個屬性可以相對的減少代碼運(yùn)行書序問題,但是如果用的太多,頁面假死次數(shù)太多。這樣反而導(dǎo)致用戶體驗(yàn)不佳~!
$.Ajax()中 async 和success的官方的解釋:
async Boolean Default: true By default, all requests are sent asynchronous (e.g. this is set to true by default). If you need synchronous requests, set this option to false. Note that synchronous requests may temporarily lock the browser, disabling any actions while the request is active. success Function A function to be called if the request succeeds. The function gets passed two arguments: The data returned from the server, formatted according to the 'dataType' parameter, and a string describing the status. This is an Ajax Event.
在這里,async默認(rèn)的設(shè)置值為true,這種情況為異步方式,就是說當(dāng)ajax發(fā)送請求后,在等待server端返回的這個過程中,前臺會繼續(xù) 執(zhí)行ajax塊后面的腳本,直到server端返回正確的結(jié)果才會去執(zhí)行success,也就是說這時候執(zhí)行的是兩個線程,ajax塊發(fā)出請求后一個線程 和ajax塊后面的腳本(另一個線程)例:
$.ajax({ type:"POST", url:"Venue.aspx?act=init", dataType:"html", success:function(result){ //function1() f1(); f2(); } failure:function (result) { alert('Failed'); }, }
function2();
在上例中,當(dāng)ajax塊發(fā)出請求后,他將停留function1(),等待server端的返回,但同時(在這個等待過程中),前臺會去執(zhí)行function2(),也就是說,在這個時候出現(xiàn)兩個線程,我們這里暫且說為function1() 和function2()。
當(dāng)把a(bǔ)syn設(shè)為false時,這時ajax的請求時同步的,也就是說,這個時候ajax塊發(fā)出請求后,他會等待在function1()這個地方,不會去執(zhí)行function2(),知道function1()部分執(zhí)行完畢。
以上內(nèi)容,就是本文給大家介紹的jquery中的ajax同步和異步詳解,希望大家喜歡。
- jQuery中Ajax的get、post等方法詳解
- jQuery中ajax - post() 方法實(shí)例詳解
- jQuery中ajax - get() 方法實(shí)例詳解
- 實(shí)例詳解angularjs和ajax的結(jié)合使用
- 談?wù)刯Query Ajax用法詳解
- jQuery學(xué)習(xí)筆記之Ajax用法實(shí)例詳解
- jQuery實(shí)現(xiàn)form表單基于ajax無刷新提交方法詳解
- jquery+ajax實(shí)現(xiàn)注冊實(shí)時驗(yàn)證實(shí)例詳解
- jQuery使用$.ajax進(jìn)行即時驗(yàn)證實(shí)例詳解
- Jsonp 關(guān)鍵字詳解及json和jsonp的區(qū)別,ajax和jsonp的區(qū)別
- jQuery中ajax的load()與post()方法實(shí)例詳解
- json傳值以及ajax接收詳解
- Ajax基礎(chǔ)詳解教程(一)
相關(guān)文章
編寫輕量ajax組件01-與webform平臺上的各種實(shí)現(xiàn)方式比較
這篇文章主要介紹了編寫輕量ajax組件01-與webform平臺上的各種實(shí)現(xiàn)方式比較,需要的朋友可以參考下2015-11-11pushState實(shí)現(xiàn)Ajax無刷新頁面切換
這篇文章主要介紹了pushState實(shí)現(xiàn)Ajax無刷新頁面切換的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11ajax接收Date類型的數(shù)據(jù)時會把數(shù)據(jù)轉(zhuǎn)換為時間戳
ajax接收Date類型的數(shù)據(jù)時將會把數(shù)據(jù)轉(zhuǎn)換為時間戳,下面是具體的示例,大家可以參考下2014-05-05