久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長(zhǎng)資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      ajax默認(rèn)是同步還是異步

      ajax默認(rèn)是異步提交;AJAX中根據(jù)async值的不同分為同步“false”和異步“true”,而默認(rèn)情況下async值是true(異步提交)。這樣做的好處就是能夠通過局部刷新的方式提高用戶的體驗(yàn),同時(shí)還能節(jié)省資源,減少數(shù)據(jù)庫(kù)的壓力。

      ajax默認(rèn)是同步還是異步

      本教程操作環(huán)境:windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。

      ajax默認(rèn)提交方式是異步提交,這樣做的好處就是能夠通過局部刷新的方式提高用戶的體驗(yàn),同時(shí)還能節(jié)省資源,減少數(shù)據(jù)庫(kù)的壓力。

      AJAX中根據(jù)async的值不同分為同步(async = false)和異步(async = true)

      $.ajax({          type: "post",         url: "path",         cache:false,         async:false,          dataType: ($.browser.msie) ? "text" : "xml",           success: function(xmlobj){                        function1(){};         }  });  function2(){};

      默認(rèn)情況下async是true(異步提交)。

      改成同步的方法就是將async的默認(rèn)值改成false,一般都是true或者不寫,如果改成false就會(huì)失去ajax的本身作用。

      一、什么是同步請(qǐng)求:(false)

      同步請(qǐng)求即是當(dāng)前發(fā)出請(qǐng)求后,瀏覽器什么都不能做,必須得等到請(qǐng)求完成返回?cái)?shù)據(jù)之后,才會(huì)執(zhí)行后續(xù)的代碼,相當(dāng)于是排隊(duì),前一個(gè)人辦理完自己的事務(wù),下一個(gè)人才能接著辦。也就是說,當(dāng)JS代碼加載到當(dāng)前AJAX的時(shí)候會(huì)把頁面里所有的代碼停止加載,頁面處于一個(gè)假死狀態(tài),當(dāng)這個(gè)AJAX執(zhí)行完畢后才會(huì)繼續(xù)運(yùn)行其他代碼頁面解除假死狀態(tài)(即當(dāng)ajax返回?cái)?shù)據(jù)后,才執(zhí)行后面的function2)。

      二、什么是異步請(qǐng)求:(true)

      異步請(qǐng)求就當(dāng)發(fā)出請(qǐng)求的同時(shí),瀏覽器可以繼續(xù)做任何事,Ajax發(fā)送請(qǐng)求并不會(huì)影響頁面的加載與用戶的操作,相當(dāng)于是在兩條線上,各走各的,互不影響。

      一般默認(rèn)值為true,異步。異步請(qǐng)求可以完全不影響用戶的體驗(yàn)效果,無論請(qǐng)求的時(shí)間長(zhǎng)或者短,用戶都在專心的操作頁面的其他內(nèi)容,并不會(huì)有等待的感覺。

      同步和異步有什么不同:

      異步:在異步模式下,當(dāng)我們使用AJAX發(fā)送完請(qǐng)求后,可能還有代碼需要執(zhí)行。這個(gè)時(shí)候可能由于種種原因?qū)е路?wù)器還沒有響應(yīng)我們的請(qǐng)求,但是因?yàn)槲覀儾捎昧水惒綀?zhí)行方式,所有包含AJAX請(qǐng)求代碼的函數(shù)中的剩余代碼將繼續(xù)執(zhí)行。如果我們是將請(qǐng)求結(jié)果交由另外一個(gè)JS函數(shù)去處理的,那么,這個(gè)時(shí)候就好比兩條線程同時(shí)執(zhí)行一樣。

      同步:在同步模式下,當(dāng)我們使用AJAX發(fā)送完請(qǐng)求后,后續(xù)還有代碼需要執(zhí)行,我們同樣將服務(wù)器響應(yīng)交由另一個(gè)JS函數(shù)去處理,但是這時(shí)的代碼執(zhí)行情況是:在服務(wù)器沒有響應(yīng)或者處理響應(yīng)結(jié)果的JS函數(shù)還沒有處理完成return時(shí),包含請(qǐng)求代碼的函數(shù)的剩余代碼是不能夠執(zhí)行的。就好比單線程一樣,請(qǐng)求發(fā)出后就進(jìn)入阻塞狀態(tài),知道接觸阻塞余下的代碼才會(huì)繼續(xù)執(zhí)行。

      看以下代碼:

      var flag=true; var index=0; $.ajax({   url: "",   success: function(data){     flag=false;   }  }); while(flag){   index++; } alert(index);

      最終程序進(jìn)入了一個(gè)死循環(huán)

      看以下代碼:

      var flag=true; $.ajax({   url: "",   success: function(data){     flag=false;   }  }); alert(flag);

      最終結(jié)果是true

      js是單線程的,由于執(zhí)行ajax請(qǐng)求會(huì)消耗一定的時(shí)間,甚至出現(xiàn)了網(wǎng)絡(luò)故障而遲遲得不到返回結(jié)果;這時(shí),如果同步執(zhí)行的話,就必須等到ajax返回結(jié)果以后才能執(zhí)行接下來的代碼,如果ajax請(qǐng)求需要1分鐘,程序就得等1分鐘。如果是異步執(zhí)行的話,在等在server端返回的這個(gè)過程中,前臺(tái)會(huì)會(huì)繼續(xù)執(zhí)行ajax塊后面的腳本,直到server端返回正常的結(jié)果才會(huì)執(zhí)行success,這時(shí)候執(zhí)行的是兩個(gè)線程,ajax塊發(fā)出請(qǐng)求后一個(gè)線程和ajax塊后面腳本

      var flag=true; var index=0; $.ajax({   url: "",   async:false,   success: function(data){     flag=false;   }  }); while(flag){   index++; } alert(index);

      最終結(jié)果是0

      【相關(guān)教程推薦:AJAX視頻教程】

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)