关于事件监听版本与事件解绑

一、onclick(L0版本)

不可叠加

<script>  
        const btn = document.querySelector('button')
        // L0版本:
        btn.onclick = function() {
            alert(123)
        }
        btn.onclick = function() {
            alert(456)
        }
        //后面把前面覆盖掉 弹出 456
</script>
  • 同一个对象,后面注册的事件会覆盖前面注册(同一个事件)

  • 直接使用null覆盖就可以实现事件的解释

  • <script>
    //绑定事件
    btn.onclick = function(){
        alert('点击了')
    }
    //解绑事件
    btn.onclick = null
    </script>
  • 都是冒泡阶段执行的(只有冒泡,没有捕获)

二、addEventListener(L2版本)

可叠加

<script>
        const btn = document.querySelector('button')
        // L2版本:
        btn.addEventListener('click', function () {
            alert(11)
        })
        btn.addEventListener('click', function () {
            alert(22)
        })
        //弹出 11 后 ,再弹出 22
</script>

(既能冒泡也能捕获)

事件解绑语法:removeEventListener(事件类型, 事件处理函数, [获取捕获或者冒泡阶段])

<script>
    const btn = document.querySelector('button')
    function fn(){
        alert('点击了')
    }
    btn.addEventListener('click', fn) //函数要有函数名
    btn.removeEventListener('click', fn)
</script>
  • 后面注册的事件不会覆盖前面注册的事件(同一个事件)

  • 可以通过第三个参数去确定是在冒泡或者捕获阶段执行(测试)

  • 匿名函数无法被解绑(所以函数要有名)

  • 10
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值