清理自定义元素中的事件侦听器
cleaning up event listeners in custom elements
在attachedCallback
中注册事件侦听器时,我有责任确保在detachedCallback
中再次删除这些侦听器吗?
如下面的最小示例所示,该模式是相当可预测的,所以我想知道浏览器是否已经解决了这个问题?
<my-element>0</my-element>
class MyElement extends HTMLElement {
createdCallback() {
this.update = this.update.bind(this);
}
attachedCallback() {
this.addEventListener("click", this.update);
}
detachedCallback() {
this.removeEventListener("click", this.update);
}
update() {
this.textContent = Math.random();
}
}
document.registerElement("my-element", {
prototype: MyElement.prototype
});
当
detachedCallback()
方法中的Event Listeners
附加到window
或document
等对象时,您应该删除它们,这些对象将在自定义元素的生命周期之后保留。
但是,如果Event Listener
附加到自定义元素本身(或其正确 DOM 中的任何元素),则在其所有者元素被销毁时,它将被删除。也就是说,在上面的示例中,您不必针对this
调用removeEventListener()
。
相关文章:
- 如何在for循环中添加事件侦听器
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何使用我的Jquery代码创建委托事件侦听器
- 'mousemove'画布中的事件侦听器-指针仅在最后一个矩形中更改
- 为什么此事件侦听器不工作
- 是否可以在数字输入框中的小按钮中添加事件侦听器
- 在Google Chrome扩展中添加事件侦听器
- SVG元素在转换后会丢失事件侦听器
- jQuery事件侦听器多次启动
- 如何在不删除类似侦听器的情况下从父对象中删除jQuery事件侦听器