我的家園

          我的家園

          先來看以下代碼:

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

          ?請問最后alert的index的結果是多少?

          可能有人會說0唄。實際上卻沒那么簡單。大家可以自己試試看。可以看到最終程序進入了一個死循環!怎么會這樣呢!

          我們在看一段代碼:

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

          ?

          大家看最后alert出flag的值是多少呢?沒錯,是true!為什么呢?明明我們在ajax請求成功了將flag設為false,怎么還是true呢?

          這實際上是Ajax的異步機制造成的。

          這里解釋一下,同步和異步。js是單線程的,由于執行ajax請求會消耗一定的時間,甚至出現了網絡故障而遲遲得不到返回結果;這時,如果同步執行的話,就必須等到ajax返回結果以后才能執行接下來的代碼,如果ajax請求需要1分鐘,程序就得等1分鐘。如果是異步執行的話,就是告訴ajax代碼“老兄,既然你遲遲不返回結果,我先不等你了,我還有一大堆代碼要執行,等你執行完了給我說一下”。

          Ajax默認是異步請求的,所以就出現了上面我們看到的結果。也就是ajax里面的代碼還沒有執行完,先執行了下面的代碼。

          ?

          那么如何使Ajax執行同步請求呢?這就需要設置async。代碼如下:

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

          ?async默認是true,也就是異步,我們設置為false,即為同步。這時我們再看看結果吧。



          已有 0 人發表留言,猛擊->>這里<<-參與討論


          ITeye推薦



          Feedback

          # re: javascript Ajax 同步請求與異步請求的問題  回復  更多評論   

          2012-09-20 21:58 by 1900
          感謝作者,解決了我困惑

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 大田县| 南通市| 普宁市| 贡山| 巴东县| 元江| 樟树市| 利辛县| 类乌齐县| 巴彦淖尔市| 沈阳市| 贵港市| 太康县| 甘肃省| 扎赉特旗| 北流市| 六安市| 泗水县| 鞍山市| 赤城县| 敦煌市| 开封市| 九江县| 荣成市| 玉屏| 宿松县| 公主岭市| 宜黄县| 湘潭市| 乌兰察布市| 富裕县| 三亚市| 宁波市| 石屏县| 洛宁县| 张家界市| 饶阳县| 亳州市| 新蔡县| 滕州市| 腾冲县|