html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

IE浏览器IFrame对象内存不释放问题解决方法_javascript技巧_

[ ] 已经帮助:人解决问题

最近项目组发现在使用showModalDialog弹出窗体中如果包含IFrame对象,则IFrame对象占用的内存资源在窗体关闭后不会释放。弹出关闭反复多次后,IE浏览器内存占用可超过数百M,严重时IE浏览器报错,且无法关闭,只能通过杀进程的方式重启浏览器。经测试,使用open方式弹出也存在该问题。Y6rHTML5中文学习网 - HTML5先行者学习网

在IE8浏览器中,open和showModalDialog弹出的内存占用有差异:Y6rHTML5中文学习网 - HTML5先行者学习网

open方式弹出的窗体占用的是一个独立的iexplorer.exe进程;Y6rHTML5中文学习网 - HTML5先行者学习网

showModalDialog方式弹出的窗体使用和父窗体相同的iexplorer.exe进程;Y6rHTML5中文学习网 - HTML5先行者学习网

经过搜索,发现解决办法是在窗体关闭前,从窗体中删除IFrame对象,代码如下:Y6rHTML5中文学习网 - HTML5先行者学习网

<span style="font-size:18px">var el = document.getElementById("scanIf");el.src="";el.contentWindow.document.write('');el.contentWindow.document.clear();var p = el.parentNode;p.removeChild(el);</span>

但是测试的时候,发现有两个限制:Y6rHTML5中文学习网 - HTML5先行者学习网

1. el.src可能还没有执行完,就执行后面的语句,如果IFrame中包含的是跨域内容,则会提示没有权限;Y6rHTML5中文学习网 - HTML5先行者学习网

2. 窗体关闭的比脚本执行的快,内存仍然没有释放;Y6rHTML5中文学习网 - HTML5先行者学习网

经过修改,最终脚本如下:Y6rHTML5中文学习网 - HTML5先行者学习网

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"><HTML><HEAD><TITLE></TITLE><BODY onbeforeunload="return unloadHandler();"><IFRAME id="scanIf" width="800px" height="600px" src = "http://www.baidu.com"></IFRAME><SCRIPT type="text/javascript">function unloadHandler(notip) {// 取消窗口关闭时的监听事件document.getElementsByTagName("BODY")[0].onbeforeunload = null;var el = document.getElementById("scanIf");if (el) {el.src = "";setTimeout(cycleClear, 100);return "提示:请点击取消按钮,当前窗口会自动关闭。";}return true;}function cycleClear() {try {var el = document.getElementById("scanIf");if (el) {el.contentWindow.document.write('');el.contentWindow.document.clear();var p = el.parentNode;p.removeChild(el);}window.close();} catch (e) {setTimeout(cycleClear, 100);}}//window.onunload = unloadHandler;</SCRIPT><input type="button" value="remove" onclick="unloadHandler();"></BODY></HTML>
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助