全局防止监听事件重复添加

情景:每次echart图都加了个监听,浏览器缩放,改变echart大小。这时候每次重新画图都会发起新的监听。从而导致监听越来越多。

window._addEventListener = window.addEventListener//为了接管事件的同时保证出入参不变,复制一份(复制指针地址不同)
const func = new Map()
window.addEventListener = (a, b, c) => {
  if (a !== 'resize') return window._addEventListener(a, b, c)//为了只接管名字为‘resize’的
  if (func.has(String(b))) {//如果这个监听以前加载过了,就remove它重新加。
    window.removeEventListener(a, func.get(String(b)), c)
    func.set(String(b), b)
    return window._addEventListener(a, b, c)
  }
  func.set(String(b), b)
  return window._addEventListener(a, b, c)
}

这里为什么要用map存一下呢,涉及到监听的区别,如何判别监听是哪个呢?监听有三个参数,每次只有第二个不同,第二个就是一个方法,方法区分同与不同:

F12控制台试试
let zz1 = () => {}
let zz2 = () => {}

zz1 == zz2    //false
String(zz1) == String(zz2)    //true

于是就利用了这个。
ps这个也说明了,当刷新当前页多次以后,真正在生效的监听是最后一次进去的,虽然他们都长得一样,但是方法识别起来不同

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值