美文网首页
【js进阶】e.target和e.currentTarget

【js进阶】e.target和e.currentTarget

作者: SophieRabbit | 来源:发表于2020-08-17 16:33 被阅读0次

    MDN中对target的解释为,一个触发事件的对象的引用, 当事件处理程序在事件的冒泡或捕获阶段被调用时。

    而对于currentTarget,它指的是当事件遍历DOM时,标识事件的当前目标。它总是引用事件处理程序附加到的元素,而不是event.target,它标识事件发生的元素

    举个例子来说明。

    事件冒泡阶段:

    <!DOCTYPE html>

    <html>

    <head>

      <meta charset="utf-8">

      <title>JS Bin</title>

    </head>

    <body>

      <ul>

        <li>hello 1</li>

        <li>hello 2</li>

        <li>hello 3</li>

        <li>hello 4</li>

      </ul>

      <script>

        let ul = document.querySelectorAll('ul')[0]

        let aLi = document.querySelectorAll('li')

        ul.addEventListener('click',function(e){

          let oLi1 = e.target 

          let oLi2 = e.currentTarget

            console.log(oLi1)  //  被点击的li

            console.log(oLi2)  // ul

            console.og(oLi1===oLi2)  // false

        })

      </script>

    </body>

    </html>

    我们知道,e.target可以用来实现事件委托,该原理是通过事件冒泡(或者事件捕获)给父元素添加事件监听,e.target指向引发触发事件的元素,如上述的例子中,e.target指向用户点击的li,由于事件冒泡,li的点击事件冒泡到了ul上,通过给ul添加监听事件而达到了给每一个li添加监听事件的效果,而e.currentTarget指向的是给绑定事件监听的那个对象,即ul,从这里可以发现,e.currentTarget===this返回true,而e.target===this返回false。e.currenttarget和e.target是不相等的。

    链接:https://www.jianshu.com/p/1dd668ccc97a

    相关文章

      网友评论

          本文标题:【js进阶】e.target和e.currentTarget

          本文链接:https://www.haomeiwen.com/subject/xnpqjktx.html