jquery不會自動回收xmlHttpRequest對象 導(dǎo)致了內(nèi)存溢出
更新時(shí)間:2012年06月18日 16:07:39 作者:
在園子里面看到kuibono的文章說JQuery不會自動回收xmlHttpRequest對象,并且在每次Ajax請求之后都會創(chuàng)建一個(gè)新的xmlHttpRequest對象,感到驚訝,索性寫了一個(gè)程序驗(yàn)正了一下,果然如kuibono所言
之前一直都不曾注意到這一點(diǎn),今天幸虧看了kuibono的文章,下面是kuibono給出的手動回收xmlHttpRequest對象的代碼片斷:
每次jquery的Ajax請求都會創(chuàng)建一個(gè)xmlHttprequest對象,理論上講,長連接的請求是一個(gè)無限遞歸,請求數(shù)量是非常大的,但是由于每次請求都會建立一個(gè)新的xmlhttprequest,而且jquery不會自動回收資源,所以導(dǎo)致了內(nèi)存溢出。
通過查看jquery API,發(fā)現(xiàn)jquery還有一個(gè) complete對象,是請求完成后回調(diào)函數(shù) (請求成功或失敗之后均調(diào)用)。 同時(shí)有兩個(gè)參數(shù)XMLHttpRequest, textStatus。所以,我們只需要在請求完成后,將傳回的XMLHttprequest對象手工回收即可,代碼如下:
$.ajax({
url: "http://www.dbjr.com.cn",
data: { name: "xxxx" },
dataType: "xml",
success: function (data, textStatus) {
//do something...
},
complete: function (XHR, TS) { XHR = null }
});
每次jquery的Ajax請求都會創(chuàng)建一個(gè)xmlHttprequest對象,理論上講,長連接的請求是一個(gè)無限遞歸,請求數(shù)量是非常大的,但是由于每次請求都會建立一個(gè)新的xmlhttprequest,而且jquery不會自動回收資源,所以導(dǎo)致了內(nèi)存溢出。
通過查看jquery API,發(fā)現(xiàn)jquery還有一個(gè) complete對象,是請求完成后回調(diào)函數(shù) (請求成功或失敗之后均調(diào)用)。 同時(shí)有兩個(gè)參數(shù)XMLHttpRequest, textStatus。所以,我們只需要在請求完成后,將傳回的XMLHttprequest對象手工回收即可,代碼如下:
復(fù)制代碼 代碼如下:
$.ajax({
url: "http://www.dbjr.com.cn",
data: { name: "xxxx" },
dataType: "xml",
success: function (data, textStatus) {
//do something...
},
complete: function (XHR, TS) { XHR = null }
});
您可能感興趣的文章:
- IE下使用jQuery重置iframe地址時(shí)內(nèi)存泄露問題解決辦法
- 使用jQuery Ajax功能時(shí)需要注意的一個(gè)問題(內(nèi)存溢出)
- JQuery1.4+ Ajax IE8 內(nèi)存泄漏問題
- JQuery Dialog的內(nèi)存泄露問題解決方法
- js內(nèi)存泄露的幾種情況詳細(xì)探討
- Javascript 閉包引起的IE內(nèi)存泄露分析
- 容易造成JavaScript內(nèi)存泄露幾個(gè)方面
- 權(quán)威JavaScript 中的內(nèi)存泄露模式
- 關(guān)于js內(nèi)存泄露的一個(gè)好例子
- jQuery內(nèi)存泄露解決辦法
相關(guān)文章
jQuery實(shí)現(xiàn)簡單的列表式導(dǎo)航菜單效果代碼
這篇文章主要介紹了jQuery實(shí)現(xiàn)簡單的列表式導(dǎo)航菜單效果代碼,涉及jquery操作鼠標(biāo)事件及頁面元素樣式動態(tài)變換的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08基于jQuery插件jqzoom實(shí)現(xiàn)的圖片放大鏡效果示例
這篇文章主要介紹了基于jQuery插件jqzoom實(shí)現(xiàn)的圖片放大鏡效果,結(jié)合實(shí)例形式分析了jQuery插件jqzoom的使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-01-01