JS-阻止冒泡事件与事件委托

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS-阻止冒泡事件与事件委托相关的知识,希望对你有一定的参考价值。

参考技术A

事件冒泡:开始时由最具体的元素接收,然后逐级向上传播到到 DOM 最顶层节点。

1.标准写法:利用事件对象里面的 stopPropagation()方法
e.stopPropagation()
2.非标准写法:IE 6-8 利用事件对象 cancelBubble 属性
e.cancelBubble = true;

事件委托也称为事件代理, 在 jQuery 里面称为事件委派。 不是每个子节点单独设置事件监听器,而是事件监听器设置在其父节点上,然后利用冒泡原理影响设置每个子节点。
如:给 ul 注册点击事件,然后利用事件对象的 target 来找到当前点击的 li,因为点击 li,事件会冒泡到 ul 上,ul 有注册事件,就会触发事件监听器,这里只操作了一次 DOM ,提高了程序的性能。

阻止冒泡的两种方式 事件委托

技术图片

 

 

 // e.stopPropagation();  // 阻止冒泡
            e.cancelBubble = true; // 取消冒泡
 
 
 
 
技术图片

 

 

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <ul>
        <li>知否知否</li>
        <li>知否知否</li>
        <li>知否知否</li>
        <li>知否知否</li>
        <li>知否知否</li>
        <li>知否知否</li>
    </ul>

    <script>
        var ul = document.querySelector(‘ul‘);
        ul.addEventListener(‘click‘, function(e) {
            // e.target 可以得到点击的对象
            e.target.style.backgroundColor = ‘pink‘;

        })
    </script>
</body>

</html>
 
 

以上是关于JS-阻止冒泡事件与事件委托的主要内容,如果未能解决你的问题,请参考以下文章

js函数中 如何阻止事件冒泡

js阻止冒泡和默认事件(默认行为)详解

js阻止事件冒泡

jquery的mouseover方法如何阻止事件冒泡

js阻止默认事件与js阻止事件冒泡

JS中阻止默认事件与事件冒泡