javascript removeChild 导致的内存泄漏_javascript技巧
程序员文章站
2022-06-02 09:42:16
...
为得求证,自己写了一个页面来验证怎样内存泄漏。代码如下
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
点击“创建元素”后再点击“删除元素”将新创建的元素用 removeChild 将其删除,再点击“测试DIV是否还存在”来查看元素是否真的删除了,结果 alert 显示
null 。看来元素结点真的已经被删除了。那司徒正美文中所说到的内存泄露又是怎么一种情况呢?只好上 google 搜索,看是否有人也遇到 removeChild 引起内
存泄漏的问题。终于在一英文版的 msdn 发现有人在问同样的问题(LINK),我将它里面的代码稍微修改一下通过对比的方式来看一下 removeChild 引起内存泄漏的情况。
代码如下:
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;iadd();
remove();
}
alert('leak done');
}
function notLeak()
{
for(var i=0;iadd();
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 = '';
}
复制代码 代码如下:
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
点击“创建元素”后再点击“删除元素”将新创建的元素用 removeChild 将其删除,再点击“测试DIV是否还存在”来查看元素是否真的删除了,结果 alert 显示
null 。看来元素结点真的已经被删除了。那司徒正美文中所说到的内存泄露又是怎么一种情况呢?只好上 google 搜索,看是否有人也遇到 removeChild 引起内
存泄漏的问题。终于在一英文版的 msdn 发现有人在问同样的问题(LINK),我将它里面的代码稍微修改一下通过对比的方式来看一下 removeChild 引起内存泄漏的情况。
代码如下:
复制代码 代码如下:
'; 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;iadd();
remove();
}
alert('leak done');
}
function notLeak()
{
for(var i=0;iadd();
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 = '';
}
推荐阅读
-
JavaScript中的垃圾回收与内存泄漏示例详解
-
面试题之JavaScript中的闭包概念及应用(顺便普及一下内存泄漏问题)
-
JavaScript中的垃圾回收和内存泄漏
-
JavaScript内存泄漏的处理方式
-
JavaScript中内存泄漏的介绍与教程(推荐)
-
动态内存分配导致影响Javascript性能的问题
-
js removeChild 障眼法 可能出现的错误_javascript技巧
-
IE6中使用position导致页面变形的解决方案(js代码)_javascript技巧
-
关于ie的内存泄漏与javascript内存释放
-
一个js导致的jquery失效问题的解决方法_javascript技巧