最近看到司徒正美的一篇文章《移除DOM节点》,文中说到在IE中移除容器类节点,会引起内存泄露。
为得求证,自己写了一个页面来验证怎样内存泄漏。代码如下
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2 <html xmlns="http://www.w3.org/1999/xhtml">
3 <head>
4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
5 <title>测试内存泄漏</title>
6 <script type="text/javascript">
7 function creatDiv()
8 {
9 var divObj = document.createElement("div");
10 divObj.id="testDiv";
11 divObj.innerHTML = "用来测试的DIV";
12 document.getElementById("main").appendChild(divObj);
13 }
14
15 function removeDiv()
16 {
17 document.getElementById("main").removeChild(document.getElementById("testDiv"));
18 }
19
20 function checkDiv()
21 {
22 alert(document.getElementById("testDiv"));
23 }
24
25 </script>
26 </head>
27
28 <body>
29 <div id="main">
30 </div>
31 <a href='javascript:creatDiv();'>创建元素</a>
32 <br />
33 <a href='javascript:removeDiv();'>删除元素</a>
34 <br />
35 <a href='javascript:checkDiv();'>测试DIV是否还存在</a>
36 </body>
37 </html>
2 <html xmlns="http://www.w3.org/1999/xhtml">
3 <head>
4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
5 <title>测试内存泄漏</title>
6 <script type="text/javascript">
7 function creatDiv()
8 {
9 var divObj = document.createElement("div");
10 divObj.id="testDiv";
11 divObj.innerHTML = "用来测试的DIV";
12 document.getElementById("main").appendChild(divObj);
13 }
14
15 function removeDiv()
16 {
17 document.getElementById("main").removeChild(document.getElementById("testDiv"));
18 }
19
20 function checkDiv()
21 {
22 alert(document.getElementById("testDiv"));
23 }
24
25 </script>
26 </head>
27
28 <body>
29 <div id="main">
30 </div>
31 <a href='javascript:creatDiv();'>创建元素</a>
32 <br />
33 <a href='javascript:removeDiv();'>删除元素</a>
34 <br />
35 <a href='javascript:checkDiv();'>测试DIV是否还存在</a>
36 </body>
37 </html>