情景:每次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这个也说明了,当刷新当前页多次以后,真正在生效的监听是最后一次进去的,虽然他们都长得一样,但是方法识别起来不同