jquery - jQuery .html() 方法会泄漏内存吗?

标签 jquery memory memory-leaks

我正在构建一个带有 requestAnimationFrame 循环的游戏,其中包括对 jQuery html() 方法的调用。它只是更新游戏操作旁边的状态窗口中的文本。

我注意到 Chrome 的时间线监视器,DOM 节点不断上升,每分钟数千个!当我从以下位置更改代码时:

// creates a ton of DOM nodes
$("#readout").html(data);

// DOM nodes does not increase over time
document.getElementById('readout').innerHTML = data;

“内存泄漏”消失了。

最佳答案

简短回答:不。

长答案:您的页面/代码中可能还有其他内容。

内存泄漏通常是由 Javascript 引擎和 DOM 之间的循环引用引起的。例如:

var div = document.getElementById('divId');
div.onclick = function() {
    doSomething(div);
};

脚本获取对页面上 div 的引用。到目前为止,我们很好。下一行将一个函数分配给 DOM 上的事件处理程序,创建从 DOM 到 Javascript 引擎的引用 - 泄漏的一半。函数体使用标签,它创建了一个闭包——标签引用与函数一起保存,以供将来调用它。这样就完成了标签 -> 函数(DOM -> JS)和函数 -> 标签(JS -> DOM)之间的循环引用,因此 2 将一直驻留在内存中,直到浏览器的进程被销毁。

因此,为了使您提到的任何一行代码泄漏,它必须消除带有如上所述附加事件的标签(或遵循类似模式的数据)。但是,jQuery 的 .html(string) 不遗余力地阻止了这些:

// Remove element nodes and prevent memory leaks
elem = this[i] || {};
if ( elem.nodeType === 1 ) {
    jQuery.cleanData( getAll( elem, false ) );
    elem.innerHTML = value;
}

所以它会遍历 all 你正在运行 .html(string) 的标签内的标签并在它们上运行 cleanData() ,这反过来会这样做:

jQuery.removeEvent( elem, type, data.handle );

从而防止泄漏。

因此,为了使用这种方法而不是 浏览器内置的 .innerHTML 泄漏内存,您必须触发一些非常晦涩的浏览器错误(似乎不太可能),或者更有可能是某些东西else 正在发生,你把它误认为是 jQuery 的 .html(string)。

关于jquery - jQuery .html() 方法会泄漏内存吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13592562/

相关文章:

javascript - 如何从 JSON 中获取值?

c++ - 内存单元和 C++ 指针

javascript - 如何根据表格选择更新价格

javascript - 保护cordova Android应用程序的内容

javascript - 如何获取iframe对象的来源

c - 有没有办法转储所有 native 内存?

c - 分配/重新分配内存时发生内存泄漏, "5 bytes in 1 blocks are definitely lost"

c - 如何使用 C 增加 16 位机器中变量的潜在值

iphone - 在 Objective C 中检查内存分配的正确方法

.net - 任务管理器不同意 Process Explorer?