javascript removeChild 导致的内存泄漏

 更新时间:2010年08月05日 14:29:44   作者:  
最近看到司徒正美的一篇文章《移除DOM节点》,文中说到在IE中移除容器类节点,会引起内存泄露。
为得求证,自己写了一个页面来验证怎样内存泄漏。代码如下
复制代码 代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>测试内存泄漏</title>
<script type="text/javascript">
function creatDiv()
{
var divObj = document.createElement("div");
divObj.id="testDiv";
divObj.innerHTML = "用来测试的DIV";
document.getElementById("main").appendChild(divObj);
}
function removeDiv()
{
document.getElementById("main").removeChild(document.getElementById("testDiv"));
}
function checkDiv()
{
alert(document.getElementById("testDiv"));
}
</script>
</head>
<body>
<div id="main">
</div>
<a href='javascript:creatDiv();'>创建元素</a>
[br]
<a href='javascript:removeDiv();'>删除元素</a>
[br]
<a href='javascript:checkDiv();'>测试DIV是否还存在</a>
</body>
</html>


[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]

点击“创建元素”后再点击“删除元素”将新创建的元素用 removeChild 将其删除,再点击“测试DIV是否还存在”来查看元素是否真的删除了,结果 alert 显示

null 。看来元素结点真的已经被删除了。那司徒正美文中所说到的内存泄露又是怎么一种情况呢?只好上 google 搜索,看是否有人也遇到 removeChild 引起内
存泄漏的问题。终于在一英文版的 msdn 发现有人在问同样的问题(LINK),我将它里面的代码稍微修改一下通过对比的方式来看一下 removeChild 引起内存泄漏的情况。
代码如下:

复制代码 代码如下:

<html>
<head>
<title>测试 removeChild 导致的内存泄漏</title>
</head>
<body>
<a href="javascript:leak();">产生内存泄漏方式</a>
<br />
<a href="javascript:notLeak();">不产生内存泄漏方式</a>
</body>
</html>
<script>
var dialog;
function add()
{
dialog = document.createElement('div');
var html = '<div><p>Title</p></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<100000;i++){
add();
remove();
}
alert('leak done');
}
function notLeak()
{
for(var i=0;i<100000;i++){
add();
discardElement(dialog);
}
alert('notLeak done');
}
function discardElement(element) {
var garbageBin = document.getElementById('IELeakGarbageBin');
if (!garbageBin) {
garbageBin = document.createElement('DIV');
garbageBin.id = 'IELeakGarbageBin';
garbageBin.style.display = 'none';
document.body.appendChild(garbageBin);
}
// move the element to the garbage bin
garbageBin.appendChild(element);
garbageBin.innerHTML = '';
}
</script>


[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

相关文章

  • js实现延迟加载的方法

    js实现延迟加载的方法

    这篇文章主要介绍了js实现延迟加载的方法,涉及javascript中setTimeout与setInterval方法的使用技巧,需要的朋友可以参考下
    2015-06-06
  • JavaScript中数组的排序、乱序和搜索实现代码

    JavaScript中数组的排序、乱序和搜索实现代码

    JavaScript中实现数组的排序、乱序和搜索,其实所有这些功能,用一个sort()就可以完成了
    2011-11-11
  • JavaScript表单验证实例之验证表单项是否为空

    JavaScript表单验证实例之验证表单项是否为空

    表单验证几乎在每个需要注册或者是登录的网站都是必不可少,下面通过本篇文章给大家介绍JavaScript表单验证实例之验证表单项是否为空,涉及到js表单验证实例相关知识,对js表单验证实例代码需要的朋友一起学习吧
    2016-01-01
  • JavaScript实现省市联动过程中bug的解决方法

    JavaScript实现省市联动过程中bug的解决方法

    这篇文章主要为大家详细介绍了解决JavaScript实现省市联动过程中的bug,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • JS动态修改图片的URL(src)的方法

    JS动态修改图片的URL(src)的方法

    这篇文章主要介绍了JS动态修改图片的URL(src)的方法,涉及javascript操作图片src属性的技巧,非常具有实用价值,需要的朋友可以参考下
    2015-04-04
  • 微信小程序获取当前位置的详细步骤

    微信小程序获取当前位置的详细步骤

    微信小程序开发中选择地理位置就需要通过官方文档API去判断用户是否授权地理位置,用户开启授权后可直接获取地理位置,下面这篇文章主要给大家介绍了关于微信小程序获取当前位置的详细步骤,需要的朋友可以参考下
    2022-12-12
  • JavaScript 悬浮窗口实现代码

    JavaScript 悬浮窗口实现代码

    主要是window.onscroll的运用
    2009-02-02
  • JavaScript find()方法及返回数据实例

    JavaScript find()方法及返回数据实例

    这篇文章主要介绍了JavaScript中的find()方法和返回数据的内存指向,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • 微信小程序上传文件到阿里OSS教程

    微信小程序上传文件到阿里OSS教程

    这篇文章主要为大家详细介绍了微信小程序上传文件到阿里OSS教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • JavaScript如何调用C++模块中的函数

    JavaScript如何调用C++模块中的函数

    这篇文章主要给大家介绍了关于JavaScript如何调用C++模块中函数的相关资料,文中通过代码介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-01-01

最新评论