求问这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;
相关分类