同步和非同步。js是單線程的,由於執行ajax請求會消耗一定的時間,甚至出現了網路故障而遲遲得不到返回結果;這時,如果同步執行的話,就必須等到ajax返回結果以後才能執行接下來的代碼,如果ajax請求需要1分鐘,程式就得等1分鐘。如果是非同步執行的話,就是告訴ajax代碼“老兄,既然你遲遲不返回結果,我 ...
var flag=true; var index=0; $.ajax({ url: "http://www.jb51.net/", success: function(data){ flag=false; } }); while(flag){ index++; } alert(index); 進入死迴圈 或者 var flag=true; $.ajax({ url: "http://www.jb51.net/", success: function(data){ flag=false; } }); alert(flag);
//返回結果是true; 因為是非同步的所以ajax和alert是一起執行的;
同步和非同步。js是單線程的,由於執行ajax請求會消耗一定的時間,甚至出現了網路故障而遲遲得不到返回結果;這時,如果同步執行的話,就必須等到ajax返回結果以後才能執行接下來的代碼,如果ajax請求需要1分鐘,程式就得等1分鐘。如果是非同步執行的話,就是告訴ajax代碼“老兄,既然你遲遲不返回結果,我先不等你了,我還有一大堆代碼要執行,等你執行完了給我說一下”。
Ajax預設是非同步請求的,所以就出現了上面我們看到的結果。也就是ajax裡面的代碼還沒有執行完,先執行了下麵的代碼。
async預設是true,也就是非同步,我們設置為false,即為同步。