为什么 IE 对象在 document.getElementById 编辑后必须被清空?

发布于 2024-11-19 15:42:20 字数 222 浏览 4 评论 0原文

我经常在第三方 JavaScript 代码中看到 after:

var el = document.getElementById(elementId);

object 经常被清空,并且该操作的注释说它是为 IE 完成的:

el = null; // IE

真正的目的是什么?有这方面的资源吗?

I often see in third party JavaScript code that after:

var el = document.getElementById(elementId);

object is often nulled and comment along this operation says that it is done for IE:

el = null; // IE

What's the real purpose? Any resource on that?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

同尘 2024-11-26 15:42:20

通过取消引用,它们打破了 DOM 对象和 JavaScript 对象之间相应的循环依赖关系,这些对象由旧版 IE 中的不同子系统控制(因此不可能被垃圾收集)。

例如:

var el = document.getElementById(elementId);
el.onclick = function () { // here the cyclic reference is created
    /...
};

JavaScript 子系统现在拥有对 el 元素的引用,而 DOM 子系统(el 元素)拥有对 JavaScript 对象(函数加上什么)的引用。它关闭)。

不过,如果您通过 addEventListener 添加侦听器,则不必担心。

要了解有关常见内存泄漏陷阱的更多信息,请参阅 http://www.ibm。 com/developerworks/web/library/wa-memleak/

By nixing a reference they break the corresponding cyclic dependency between the DOM object and JavaScript objects, which are controlled by different sub-systems in older IE (thus being impossible to be garbage-collected).

For example:

var el = document.getElementById(elementId);
el.onclick = function () { // here the cyclic reference is created
    /...
};

The JavaScript subsystem has now a reference to the el element, and the DOM subsystem (the el element) has a reference to the JavaScript object (the function plus what it closes in).

You don't have to worry, though, if you add the listeners via addEventListener.

To read more about common memory leak pitfalls, see http://www.ibm.com/developerworks/web/library/wa-memleak/.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文