添加IFrame导致内存溢出的解决过程(IE浏览器,目前发现了原因,还未解决)...
生活随笔
收集整理的這篇文章主要介紹了
添加IFrame导致内存溢出的解决过程(IE浏览器,目前发现了原因,还未解决)...
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1、? 現象
每次動態添加iframe時,iexplore.exe進程占據的內存都會增加(大概10M左右),不會自動釋放,最終導致內存溢出
2、? 解決過程
經過網絡的一番搜索,基本上給出的解決方案是清空iframe內容,并移除iframe節點。方法如下:
var el = document.getElementById("IFrame1");if (el) {iframe = el.contentWindow;//清除文檔el.src = 'about:blank';try {iframe.document.write('');iframe.document.clear();CollectGarbage();} catch (e) { };//清除節點var _parentElement = el.parentNode;if (_parentElement) {_parentElement.removeChild(el);}}
?
此方法在重新加載iframe時都會釋放一定的內存(可以從進程中看到內存的變化),但加載后新增的內存比釋放的內存要多很多,再多次加載后還是會導致內存溢出
還有的說是IE的bug,要用CollectGarbage()函數進行垃圾回收,但經過測試,此函數沒有效果,內存溢出也不僅僅在IE存在,火狐和谷歌瀏覽器都有此現象,只是溢出程度較輕
?
?? ?使用$.get替換iframe動態加載html,同樣會導致內存溢出,看來不是iframe的原因
$.get(src, function (data) { //初始將a.html include div#iframe$("#center").empty();$("#center").html(data);});?
3、結論
? 上述方法確實釋放了一定的內存,但動態加載新的iframe后溢出了更多的內存,看來不僅僅是這方面的原因。后來經過調試代碼,發現iframe頁面引入了大量的js庫,大概有幾十種,如果刪除一些內存溢出現象就會得到緩解,看來這就是原因。下一步準備對js庫進行壓縮和合并,看能否降低內存溢出。
轉載于:https://www.cnblogs.com/gossip/p/3689604.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的添加IFrame导致内存溢出的解决过程(IE浏览器,目前发现了原因,还未解决)...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 关于cannot deserialize
- 下一篇: 2017年html5行业报告,云适配发布