解绑事件

一、事件等级

  • L0(level 0)
    • 事件源.onclick=function(){}
  • L2(level 2)
    • 事件源.addEventListener(事件类型,事件处理函数,是否捕获){}

二、L0事件解绑

  • 重新给赋值为null
    事件源.onclick=null

L2事件解绑

  • 不能使用匿名的回调函数,否则无法解绑
  • 正确解绑方式如下
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Title</title>
</head>
<body>
    <button>点击</button>
    <script>
        const btn = document.querySelector('button')

        function fn() {
            alert('点击了')
        }
        //绑定事件
        btn.addEventListener('click', fn)
        //解绑事件
        btn.removeEventListener('click', fn)
    </script>
</body>

</html>

实现点击一次后,解绑,就无法再点击

    <script>
        const btn = document.querySelector('button')

        function fn() {
            alert('点击了')
            //解绑事件
            btn.removeEventListener('click', fn)
        }

        //绑定事件
        btn.addEventListener('click', fn)

    </script>
posted @ 2023-08-17 20:01  弩哥++  阅读(8)  评论(0编辑  收藏  举报