首頁 > web前端 > js教程 > 主體

使用jQuery Ajax功能時需要注意的一個問題(記憶體溢位)_jquery

WBOY
發布: 2016-05-16 17:52:59
原創
1361 人瀏覽過

最近一哥們在做一個Ajax長連接的項目,頁面需要和伺服器保持長連接,而且在連接超時後需要重新請求連接,過程中他問我要用到什麼,我也是想都沒想就告訴他用jQuery。 jQuery不是有ajaxSuccess ajaxError這些物件嗎,在請求完成或要求失敗後重新請求不就好了。

但後來他告訴我說沒有用 jQuery,自己手寫的XMLhttprequest 。他告訴我說,一開始是用jquery寫的,而且在測試過程中也沒有出現問題。但在後來無意間發現,在頁面開啟的時候久了之後,瀏覽器資源竟然佔用非常高導致記憶體不足而崩潰了。後來抓包分析發現,每次jquery的Ajax請求都會創建一個xmlHttprequest對象,理論上講,長連接的請求是一個無限遞歸,請求數量是非常大的,但是由於每次請求都會建立一個新的xmlhttprequest,而且jquery不會自動回收資源,所以導致了記憶體溢位。

透過查看jquery API,發現jquery還有一個 complete對象,是請求完成後回呼函數 (請求成功或失敗之後均調用)。 同時有兩個參數XMLHttpRequest, textStatus。所以,我們只需要在請求完成後,將傳回的XMLHttprequest物件手動回收即可,程式碼如下:

複製程式碼


程式碼如下:


$.ajax({
url: "http://www.jb51.net",
data: { name: "xxxx" },
dataType: "xml",
success: function (data, textStatus) {
//do something...
}, complete: function (XHR, TS) { XHR = null } });
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板