JS监听事件的叠加和移除功能

2019-11-13,,,

html DOM元素有很多on开头的监听事件,如onload、onclick等,见DOM事件列表。但是同一种事件,后面注册的会覆盖前面的:

window.onresize = function(){
  alert(1);
}
window.onresize = function(){
  alert(2);
}
// 改变窗口大小时,只会弹出2 

addEventListener监听

  利用addEventListener添加监听事件,可以重复添加,并不会互相覆盖:

window.addEventListener("resize",function(){
  alert(1)
})
window.addEventListener("resize",function(){
  alert(2)
})
// 改变窗口大小时,先后弹出1和2

  注意这里面的事件是不带"on"前缀的。

removeEventListener移除监听

  removeEventListener跟addEventListener相对应,用于移除事件监听。

  如果要移除事件句柄,addEventListener() 的执行函数必须使用外部具名函数,匿名函数事件是无法移除的。

// 匿名函数事件无法移除
window.addEventListener("resize",function(){
  alert(1)
})
// 监听具名函数事件
function myResize(){
  alert(2)
}
window.addEventListener("resize",myResize)
// 移除事件监听
window.removeEventListener("resize",myResize) 

总结

以上所述是小编给大家介绍的JS监听事件的叠加和移除,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对北冥有鱼网站的支持!

您可能感兴趣的文章:

  • js中事件对象和事件委托的介绍
  • Node.js EventEmmitter事件监听器用法实例分析
  • Node.js net模块功能及事件监听用法分析
  • JavaScript键盘事件常见用法实例分析
  • JavaScript常见鼠标事件与用法分析
  • JavaScript事件对象深入详解
  • javascript中的event loop事件循环详解
  • 浅谈Vue.js 中的 v-on 事件指令的使用
  • Javascript中绑定click事件的四种方式介绍
  • JavaScript常用事件介绍

《JS监听事件的叠加和移除功能.doc》

下载本文的Word格式文档,以方便收藏与打印。