javascript - 当被观察节点被销毁时,MutationObserver 是否被销毁?

标签 javascript mutation-observers

我通过简单地观察一个节点

new MutationObserver(callback)
  .observe(shape.node, {attributes: true})

如您所见,我没有任何对观察者的引用。观察到的节点会在某个时候被销毁。

是否清理了节点和观察者的内存?还是他们让自己活着?如果是这样:我怎样才能防止这种情况发生?我不知道节点何时被删除。

Ofc 我也可以观察父级并在父级观察到“子列表已更改”时断开第一个观察者,但我想避免这种情况

最佳答案

MutationObserver 对它们正在观察的节点持有弱引用,而节点对变异观察者有强引用。这意味着在您的情况下,唯一引用观察者的是节点对象。如果节点被 GC 处理,则没有任何内容会引用观察者,因此它也将被 GC 处理。

参见 DOM Specification section 4.3.4. Garbage collection ,其中指出:

Nodes have a strong reference to registered observers in their registered observer list.

Registered observers in a node’s registered observer list have a weak reference to the node.

关于javascript - 当被观察节点被销毁时,MutationObserver 是否被销毁?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50820543/

相关文章:

javascript - 环回Mysql连接器: BIT(1) is recognized always true

javascript - 按作为字符串传递的 "grand.child.property"对对象数组进行排序的函数

javascript - MutationRecord.addedNodes 节点列表(mutationObserver)中返回的节点数

javascript - 如何使用 jQuery 检测 HTML 元素是否消失?

javascript - 如果修改 DOM 后立即调用断开连接,则不会调用 MutationObserver 回调

javascript - Angularjs 自定义表单控件范围重复

javascript - 如何仅使用单个 div 实现阅读更多功能

javascript - 如何向 d3 生成的凸包添加标签?

javascript - MutationObserver 在整个 DOM 中检测节点的性能

javascript - 如何使用 MutationObserver?