猿问

JS中的DOM泄漏和定时器泄漏

求问这DOM泄漏和定时器泄漏这个两个内存泄漏的原因?在COM树中leafRef是treeFre的一个子结,它内部的数据结构是子节点->父节点,还是父节点->子节点?


基础的DOM泄漏

当原有的DOM被移除时,子结点引用没有被移除则无法回收。


var select = document.querySelector;

var treeRef = select('#tree');


var leafRef = select('#leaf');   //在COM树中leafRef是treeFre的一个子结点


select('body').removeChild(treeRef);//#tree不能被回收入,因为treeRef还在

   解决方法:


treeRef = null;//tree还不能被回收,因为叶子结果leafRef还在

leafRef = null;//现在#tree可以被释放了  

timer定时器泄漏


var val = 0;

for (var i = 0; i < 90000; i++) {

  var buggyObject = {

    callAgain: function() {

      var ref = this;

      val = setTimeout(function() {

        ref.callAgain();

      }, 90000);

  }

}

buggyObject.callAgain();

//这个时候你无法回收buggyObject

//虽然你想回收但是timer还在

buggyObject = null;


//解决办法,先停止timer然后再回收

//解决方法,先停止定时器

clearTimeout(val);

buggyObject = null;


千巷猫影
浏览 399回答 1
1回答
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答