麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > AJAX > 正文

解決js ajax同步請求造成瀏覽器假死的問題

2024-09-01 08:33:56
字體:
來源:轉載
供稿:網友

一、問題的起因

今天做一個需求遇到了這么個情況,就是用戶個人中心有個功能,點擊按鈕,可以刷新用戶當前的積分,這個肯定需要使用到ajax的同步請求了,當時喀喀喀三下五除二寫玩了,大概代碼如下:

/**  * 異步當前用戶積分 by zgw 20161216  * @return {[type]} [description] */ function flushIntegralSum() {     //點擊按鈕刷新前修改按鈕的文案,已經去掉點擊事情,防止多次點擊  $("#flushbutton").replaceWith('<a style="color:#3fb0ff;font-size:14px;" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" id="flushbutton">正在刷新</a>');  $.ajax({   url:'URL',   type:'post',   async:false,   // data:{},   success:function(json){    json = eval('('+json+')');    if(json.url){window.location.href=json.url;return;}    $("#flushbutton").replaceWith('<a style="color:#3fb0ff;font-size:14px;" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="flushFreeSum();" id="flushbutton">刷新積分</a>');    if(json.code!=1){     alert(json.msg);    }else{     $("#free_sum").html(json.free_sum);    }    return;   }  }); }

本以為這么簡單的功能喀喀喀隨便寫寫就沒事了,在運行的時候出現了問題,當用戶點擊刷新積分按鈕時,文案沒有修改為"正在刷新",但是ajax請求發送了,于是我查看網頁代碼,發現js其實把文案和html元素綁定的onclick事件去掉了,在請求成功后有變回原來的了,但是頁面上邊文案沒有改變,當時很奇怪,不知道為什么html代碼里邊改變了,頁面卻沒有變點變化

二、了解問題原因

問題的根源:當時我進行了排查,最后發現是 "async:false" 的問題,換成異步的就沒有問題了,那為什么同步請求會產生代碼失效的問題呢?

原因:瀏覽器的渲染(UI)線程和js線程是互斥的,在執行js耗時操作時,頁面渲染會被阻塞掉。當我們執行異步ajax的時候沒有問題,但當設置為同步請求時,其他的動作(ajax函數后面的代碼,還有渲染線程)都會停止下來。即使我的DOM操作語句是在發起請求的前一句,這個同步請求也會“迅速”將UI線程阻塞,不給它執行的時間。這就是代碼失效的原因。

三、解決問題

1.我當時使用了 setTimeout 來解決,把ajax代碼放在sestTimeout中,讓瀏覽器重啟一個線程來操作,這樣就解決問題了,代碼如下:

function flushIntegralSum() {     //點擊按鈕刷新前修改按鈕的文案,已經去掉點擊事情,防止多次點擊  $("#flushbutton").replaceWith('<a style="color:#3fb0ff;font-size:14px;" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" id="flushbutton">正在刷新</a>');  setTimeout(function(){   $.ajax({    url:'URL',    type:'post',    async:false,    // data:{},    success:function(json){     json = eval('('+json+')');     if(json.url){window.location.href=json.url;return;}     $("#flushbutton").replaceWith('<a style="color:#3fb0ff;font-size:14px;" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="flushFreeSum();" id="flushbutton">刷新積分</a>');     if(json.code!=1){      alert(json.msg);     }else{      $("#free_sum").html(json.free_sum);     }     return;    }   });  },0)  }

setTimeout的第二個參數設為0,瀏覽器會在一個已設的最小時間后執行

到這里問題就解決了,但是你可以試試當你點擊按鈕的時候如果需要彈出一個gif圖片,并且圖片一直在旋轉,提示更新中,你會發現圖片雖然會顯示,但是圖片卻是不動的,那是因為雖然同步請求延遲執行了,但是它執行期間還是會把UI線程給阻塞。這個阻塞相當牛逼,連gif圖片都不動了,看起來像一張靜態圖片一樣。結論很明顯,setTimeout治標不治本,相當于把同步請求“稍稍”異步了一下,接下來還是會進入同步的噩夢,阻塞線程,這種方法只適合發請求之前操作簡單的時間短的情況

2.使用 Deferred 來解決

以上這篇解決js ajax同步請求造成瀏覽器假死的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 韩国草草影院 | 久久成人视屏 | 国产妞干网| 国内精品久久久久久久久久 | 毛片国产 | wankz100%videos | 国产一级毛片国产 | 久久精精品 | 亚洲成人免费视频在线 | 性爱视频在线免费 | 日韩美女电影 | 精品在线观看一区二区三区 | 精品国产高清一区二区三区 | 中文字幕在线观看二区 | 羞羞网站入口 | 日本成人在线免费 | 国产在线区 | 麻豆91精品91久久久 | 亚洲综合网站 | 一区二区三区欧洲 | 久久久国产电影 | 毛片大全 | 黄色一级视频 | 亚洲精品一区二区三区在线看 | 日韩激情一区二区三区 | 亚洲电影在线播放 | 国产高潮失禁喷水爽到抽搐视频 | 国产永久免费观看 | 极品销魂一区二区三区 | 得得啪在线 | 91精品观看91久久久久久国产 | 国产一区精品在线观看 | 黄色片在线免费播放 | 日本精品中文字幕 | 在线91视频| 亚洲aⅴ免费在线观看 | 免费男女乱淫真视频 | 国产精品免费久久久久久 | 999插插插 | 成人三级电影网站 | 天海翼四虎精品正在播放 |