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

2020-08-17  本文已影响0人  SophieRabbit

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

上一篇 下一篇

猜你喜欢

热点阅读