javascript removeChild 導(dǎo)致的內(nèi)存泄漏
更新時(shí)間:2010年08月05日 14:29:44 作者:
最近看到司徒正美的一篇文章《移除DOM節(jié)點(diǎn)》,文中說(shuō)到在IE中移除容器類節(jié)點(diǎn),會(huì)引起內(nèi)存泄露。
為得求證,自己寫了一個(gè)頁(yè)面來(lái)驗(yàn)證怎樣內(nèi)存泄漏。代碼如下
<!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>測(cè)試內(nèi)存泄漏</title>
<script type="text/javascript">
function creatDiv()
{
var divObj = document.createElement("div");
divObj.id="testDiv";
divObj.innerHTML = "用來(lái)測(cè)試的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();'>創(chuàng)建元素</a>
[br]
<a href='javascript:removeDiv();'>刪除元素</a>
[br]
<a href='javascript:checkDiv();'>測(cè)試DIV是否還存在</a>
</body>
</html>
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
點(diǎn)擊“創(chuàng)建元素”后再點(diǎn)擊“刪除元素”將新創(chuàng)建的元素用 removeChild 將其刪除,再點(diǎn)擊“測(cè)試DIV是否還存在”來(lái)查看元素是否真的刪除了,結(jié)果 alert 顯示
null ??磥?lái)元素結(jié)點(diǎn)真的已經(jīng)被刪除了。那司徒正美文中所說(shuō)到的內(nèi)存泄露又是怎么一種情況呢?只好上 google 搜索,看是否有人也遇到 removeChild 引起內(nèi)
存泄漏的問(wèn)題。終于在一英文版的 msdn 發(fā)現(xiàn)有人在問(wèn)同樣的問(wèn)題(LINK),我將它里面的代碼稍微修改一下通過(guò)對(duì)比的方式來(lái)看一下 removeChild 引起內(nèi)存泄漏的情況。
代碼如下:
<html>
<head>
<title>測(cè)試 removeChild 導(dǎo)致的內(nèi)存泄漏</title>
</head>
<body>
<a href="javascript:leak();">產(chǎn)生內(nèi)存泄漏方式</a>
<br />
<a href="javascript:notLeak();">不產(chǎn)生內(nèi)存泄漏方式</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需再刷新一下頁(yè)面才能執(zhí)行]
首先運(yùn)行“產(chǎn)生內(nèi)存泄漏方式”
未運(yùn)行前打開任務(wù)管理器監(jiān)控內(nèi)存大小如下:
運(yùn)行完再查看內(nèi)存大小,可以看到內(nèi)存大小已經(jīng)增加了很多。
接著我再運(yùn)行“不產(chǎn)生內(nèi)存泄漏方式”
未運(yùn)行前打開任務(wù)管理器監(jiān)控內(nèi)存大小如下:
運(yùn)行完再查看內(nèi)存大小,可以看到內(nèi)存較“產(chǎn)生內(nèi)存泄漏方式”小了很多。
PS: 為了檢驗(yàn) removeChild 導(dǎo)致的內(nèi)存泄漏 ,我 google 了很多 IE 內(nèi)存泄漏的相關(guān)文章。
相關(guān)文章如下:
http://www.cnblogs.com/dwjaissk/archive/2007/07/20/824884.html
http://bugs.dojotoolkit.org/ticket/1727
http://article.yeeyan.org/view/3407/10103
復(fù)制代碼 代碼如下:
<!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>測(cè)試內(nèi)存泄漏</title>
<script type="text/javascript">
function creatDiv()
{
var divObj = document.createElement("div");
divObj.id="testDiv";
divObj.innerHTML = "用來(lái)測(cè)試的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();'>創(chuàng)建元素</a>
[br]
<a href='javascript:removeDiv();'>刪除元素</a>
[br]
<a href='javascript:checkDiv();'>測(cè)試DIV是否還存在</a>
</body>
</html>
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
點(diǎn)擊“創(chuàng)建元素”后再點(diǎn)擊“刪除元素”將新創(chuàng)建的元素用 removeChild 將其刪除,再點(diǎn)擊“測(cè)試DIV是否還存在”來(lái)查看元素是否真的刪除了,結(jié)果 alert 顯示
null ??磥?lái)元素結(jié)點(diǎn)真的已經(jīng)被刪除了。那司徒正美文中所說(shuō)到的內(nèi)存泄露又是怎么一種情況呢?只好上 google 搜索,看是否有人也遇到 removeChild 引起內(nèi)
存泄漏的問(wèn)題。終于在一英文版的 msdn 發(fā)現(xiàn)有人在問(wèn)同樣的問(wèn)題(LINK),我將它里面的代碼稍微修改一下通過(guò)對(duì)比的方式來(lái)看一下 removeChild 引起內(nèi)存泄漏的情況。
代碼如下:
復(fù)制代碼 代碼如下:
<html>
<head>
<title>測(cè)試 removeChild 導(dǎo)致的內(nèi)存泄漏</title>
</head>
<body>
<a href="javascript:leak();">產(chǎn)生內(nèi)存泄漏方式</a>
<br />
<a href="javascript:notLeak();">不產(chǎn)生內(nèi)存泄漏方式</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需再刷新一下頁(yè)面才能執(zhí)行]
首先運(yùn)行“產(chǎn)生內(nèi)存泄漏方式”
未運(yùn)行前打開任務(wù)管理器監(jiān)控內(nèi)存大小如下:
運(yùn)行完再查看內(nèi)存大小,可以看到內(nèi)存大小已經(jīng)增加了很多。
接著我再運(yùn)行“不產(chǎn)生內(nèi)存泄漏方式”
未運(yùn)行前打開任務(wù)管理器監(jiān)控內(nèi)存大小如下:
運(yùn)行完再查看內(nèi)存大小,可以看到內(nèi)存較“產(chǎn)生內(nèi)存泄漏方式”小了很多。
PS: 為了檢驗(yàn) removeChild 導(dǎo)致的內(nèi)存泄漏 ,我 google 了很多 IE 內(nèi)存泄漏的相關(guān)文章。
相關(guān)文章如下:
http://www.cnblogs.com/dwjaissk/archive/2007/07/20/824884.html
http://bugs.dojotoolkit.org/ticket/1727
http://article.yeeyan.org/view/3407/10103
相關(guān)文章
JavaScript中數(shù)組的排序、亂序和搜索實(shí)現(xiàn)代碼
JavaScript中實(shí)現(xiàn)數(shù)組的排序、亂序和搜索,其實(shí)所有這些功能,用一個(gè)sort()就可以完成了2011-11-11JavaScript表單驗(yàn)證實(shí)例之驗(yàn)證表單項(xiàng)是否為空
表單驗(yàn)證幾乎在每個(gè)需要注冊(cè)或者是登錄的網(wǎng)站都是必不可少,下面通過(guò)本篇文章給大家介紹JavaScript表單驗(yàn)證實(shí)例之驗(yàn)證表單項(xiàng)是否為空,涉及到j(luò)s表單驗(yàn)證實(shí)例相關(guān)知識(shí),對(duì)js表單驗(yàn)證實(shí)例代碼需要的朋友一起學(xué)習(xí)吧2016-01-01JavaScript實(shí)現(xiàn)省市聯(lián)動(dòng)過(guò)程中bug的解決方法
這篇文章主要為大家詳細(xì)介紹了解決JavaScript實(shí)現(xiàn)省市聯(lián)動(dòng)過(guò)程中的bug,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12JS動(dòng)態(tài)修改圖片的URL(src)的方法
這篇文章主要介紹了JS動(dòng)態(tài)修改圖片的URL(src)的方法,涉及javascript操作圖片src屬性的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04JavaScript 懸浮窗口實(shí)現(xiàn)代碼
主要是window.onscroll的運(yùn)用2009-02-02JavaScript find()方法及返回?cái)?shù)據(jù)實(shí)例
這篇文章主要介紹了JavaScript中的find()方法和返回?cái)?shù)據(jù)的內(nèi)存指向,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04JavaScript如何調(diào)用C++模塊中的函數(shù)
這篇文章主要給大家介紹了關(guān)于JavaScript如何調(diào)用C++模塊中函數(shù)的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01