跳到主要内容

编写一个通用的事件监听函数

首先一个 html 结构代码

<button id="btn1">按钮</button>

实现事件绑定

// 事件绑定函数
function bindEvent(elem, type, fn) {
elem.addEventListener(type, fn)
}
const btn1 = document.getElementById('btn1')
bindEvent(btn1, 'click', event => {
console.log(event.target) // <button id="btn1">按钮</button>
event.preventDefault() // 阻止默认行为
alert('clicked')
})

通用的事件监听函数

// 通用的事件绑定函数
function bindEvent(elem, type, selector, fn) {
if (fn == null) {
fn = selector
selector = null
}
elem.addEventListener(type, event => {
const target = event.target
if (selector) {
// 代理绑定
if (target.matches(selector)) {
fn.call(target, event)
}
} else {
// 普通绑定
fn.call(target, event)
}
})
}
const btn1 = document.getElementById('btn1')
bindEvent(btn1, 'click', function(event){ //
console.log(this.innerHTML) // 按钮
})

需要注意的是 this.innerHTML 的指向,此时不能是 event=> , 而需要使用 function(event)