浏览器内部循环引用导致的内存泄露

一.直接循环内存引用

1.自身进行引用的 DOM 对象和不在树中的对象间的循环引用

function leaktest1() {       var elem1 = document.createElement("DIV");       elem1.thing = elem1; }

2.不在树中的 DOM 对象间的循环引用

function leaktest2() {      var elem1 = document.createElement("DIV");     var elem2 = document.createElement("DIV");     elem1.thing = elem2;      elem2.item = elem1; }

3.DOM 对象和 JScript 对象间的循环引用

 function leaktest3() {      var x = new Object();      x.obj = document.createElement("DIV");     x.obj.jsobj = x; }

4.在临时标记中时 DOM 对象间的循环引用

 function leaktest4() {      var elem1 = document.createElement("DIV");     var elem2 = document.createElement("DIV");     elem1.appendChild(elem2);      elem1.thing = elem2;     elem2.item = elem1; }

5.使用 removeNode 将 DOM 对象从树中删除时,DOM 对象间的循环引用

 function leaktest5() {     var elem1 = document.createElement("DIV");      document.body.appendChild(elem1);     elem1.thing = elem1;     elem1.removeNode(true); }

6.使用 innerHTML 将 DOM 对象从树中删除时,DOM 对象间的循环引用
function leaktest6() {     var elem1 = document.createElement("DIV");     document.body.appendChild(elem1);     elem1.thing = elem1;     elem1.parentElement.innerHTML = ""; } 

二.闭包引起的循环内存引用

1.带有动态创建的元素的闭包

function leaktest7() {     var elem = document.createElement("DIV");     elem.onload = function (){         var y = elem;     }     }

2.带有添加到树中并使用 removeNode 删除的元素的闭包

function leaktest8(){     var elem = document.createElement("DIV");     document.body.appendChild(elem);     elem.onload = function () {         var y = elem;         }     elem.removeNode(); }

 

3.带有添加到树中并使用 innerHTML 删除的元素的闭包

 

function leaktest9() {     var elem = document.createElement("DIV");     document.body.appendChild(elem);     elem.onload = function () {         var y = elem;         }     elem.parentElement.innerHTML = ""; }

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值