为得求证,自己写了一个页面来验证怎样内存泄漏。代码如下
<script type="text/javascript"> <br>function creatDiv() <br>{ <br>var divObj = document.createElement("div"); <br>divObj.id="testDiv"; <br>divObj.innerHTML = "用来测试的DIV"; <br>document.getElementById("main").appendChild(divObj); <br>} <br>function removeDiv() <br>{ <br>document.getElementById("main").removeChild(document.getElementById("testDiv")); <br>} <br>function checkDiv() <br>{ <br>alert(document.getElementById("testDiv")); <br>} <br></script>
创建元素
[br]
删除元素
[br]
测试DIV是否还存在
'; dialog.innerHTML = html; document.body.appendChild(dialog); dialog.style.marginTop='200px'; dialog.style.marginLeft='200px'; } function remove() { document.body.removeChild(dialog); dialog=null; } function leak() { for(var i=0;i
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
首先运行“产生内存泄漏方式”
未运行前打开任务管理器监控内存大小如下:
运行完再查看内存大小,可以看到内存大小已经增加了很多。
接着我再运行“不产生内存泄漏方式”
未运行前打开任务管理器监控内存大小如下:
运行完再查看内存大小,可以看到内存较“产生内存泄漏方式”小了很多。
PS: 为了检验 removeChild 导致的内存泄漏 ,我 google 了很多 IE 内存泄漏的相关文章。
相关文章如下:
http://www.cnblogs.com/dwjaissk/archive/2007/07/20/824884.html
http://bugs.dojotoolkit.org/ticket/1727
http://article.yeeyan.org/view/3407/10103











