Js事件监听封装(支持匿名函数)
这篇讲的是JavaScript中一个常见但容易被忽视的痛点:如何优雅地取消事件监听,尤其是当使用匿名函数绑定时。作者从实际开发中“想解绑却拿不到函数引用”的困境出发,提出了一套简洁的封装方案。 核心思路是利用一个哈希表(handleHash)作为事件类型的索引,在绑定时不仅执行原始函数,还将内部包装函数的引用缓存到对应的数组中。这样,即使外部是匿名函数,内部通过 arguments.callee(在非严格模式下)依然能获取其引用并保存下来。解绑时,则遍历该数组,逐个移除监听器。 这个方案的巧妙之处在于,它通过一层轻量的“包装”和“缓存”,完全兼容了 addEventListener 与 attachEvent,同时将匿名函数的“不可见引用”问题巧妙地转化为可管理的内部引用,让开发者可以随意使用匿名函数而无需担心内存泄漏或无法解绑。实际使用时,只需像普通绑定一样调用 bind,在需要时用 unbind 按事件名一键清理即可。