Javascript 删除节点后是否需要将手动将事件解绑?

信息发布:soゝso 发布日期:2016-08-22 18:25 热度:435 分享到:

segmentfault 上有一个问题:Javascript 删除节点后是否需要将手动将事件解绑?

问题描述:

如果一个单页应用需要大量操作dom节点,并且节点上绑定的事件比较多,需要手动在删除节点的时候解绑吗?删除节点后监听器是否还存在啊?


问题分析:

从问题的描述来看,其实提问者的关注点,在性能方面。那么我现在把其他的人的回答,综合整理一下。

let parent = document.body
let child = document.createElement('div')
child.addEventListener('click', clickHandler)
parent.appendChild(child)

当我们移除 child 对象后:

parent.removeChild(child)

此时对于 DOM Tree 来说 child 当然是不存在的了,但是内存中依然有对于它的引用,也就是 child 本身,只不过它没有在 DOM Tree 中而已。因此,clickHandler 也同样驻留在内存中。

当然了移除事件回调也不一定非要用 removeEventListener,像上例那种情况使用最简单的办法可以 child = null 即可。

以上说的是最基本的情况,现实中其实要考虑很多因素。比如你说你做的是一个 SPA,那么假设你用了某种框架吧。现在的 SPA 基本上都会告诉你:

如果你要做 DOM 操作,不要直接写在 Controller(或其他)地方,而是要写在组件(比如 Directive)里

Basically,这么做的原因是框架的组件机制都会维护自身的生命周期,如果你要处理类似本问题中的“善后”工作,你可以利用这些生命周期来实现。框 架会保障一些基本的东西,比如说判断 DOM Element 是否还存在于 DOM Tree 中,或者是否还有引用等等(一般来说,组件化有一个很大的好处就是Isolation ,也就是避免到处都是引用,因为人工判断和跟踪会很累很烦很容易出错)。

老的浏览器存在很多 Bug,类似的“善后”工作可能要考虑的更细致和周全一些。

本文主题

如果本文对你有帮助,那么请你赞助我,让我更有激情的写下去,帮助更多的人。

¥我需要走的更远,点击我 赞助。 如果还有疑问,点击我加群,为你提供最好的解答。


工具导航地图

 
Nodejs + socket Demo 赞助二维码 赞助名单 百度口碑点赞 查看QQ群美女帅哥 点击加QQ群 听音乐 开启弹幕 X
反馈意见