js中event.target,this

event.target这是注册事件时的对象,或者它的子元素。通常用于比较 event.target 和 this 来确定事件是不是由于冒泡而触发的。经常用于事件冒泡时处理事件委托。

1.this和event.target的区别:

js中事件是会冒泡的,所以this是可以变化的,但event.target不会变化,它永远是直接接受事件的目标DOM元素;

 1 <!DOCTYPE html>

 2   <html>

 3   <head>

 4     <style>  span, strong, p {     padding: 8px; display: block; border: 1px solid #999;  }      </style>

 5     <script src="http://code.jquery.com/jquery-latest.min.js"></script>

 6   </head>

 7  <body>

 8       <div id="log"></div>

 9   <div>

10     <p> 

11      <strong><span>click</span></strong>

12     </p>

13   </div>

14   <script>$("body").click(function(event) {

15     $("#log").html("clicked: " + event.target.nodeName);  });

16   </script>

17     </body>

18   </html>
 1 <!DOCTYPE html>

 2   <html>

 3   <head>

 4     <script src="http://code.jquery.com/jquery-latest.min.js"></script>

 5   </head>

 6   <body>

 7   <ul>

 8     <li>item 1

 9       <ul>

10         <li>sub item 1-a</li>

11         <li>sub item 1-b</li>

12       </ul>

13     </li>

14     <li>item 2

15       <ul>

16         <li>sub item 2-a</li>

17         <li>sub item 2-b</li>

18       </ul> 

19     </li>

20   </ul>

21   <script>

22     function handler(event) {

23       var $target = $(event.target);

24       if( $target.is("li") ) {

25         $target.children().toggle();

26       }

27       console.log($target);

28     }

29     $("ul").click(handler).find("ul").hide();

30   </script>

31     </body>

32   </html>
View Code

 

2.this和event.target都是dom对象,如果要使用jquey中的方法可以将他们转换为jquery对象:$(this)和$(event.target);

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

 2 <html xmlns="http://www.w3.org/1999/xhtml">

 3 <head>

 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

 5 <title>无标题文档</title>

 6 <script type="text/javascript" src="http://www.css88.com/tool/css3Preview/jquery-1.4.2.min.js"></script>

 7 <script type="text/javascript">

 8 $(function(){

 9 $("li").live("click",function(event){

10 $("#temp").html("clicked: " + event.target.nodeName);

11 $(this).css("color","#FF3300");

12 event.stopPropagation();

13 })

14 });

15 </script>

16 </head>

17  

18 <body>

19 <div id="temp"></div>

20 <ul class="JQ-content-box" style="padding:20px; background:#FFFFFF">

21 <li>第一行

22 <ul>

23 <li>这是公告标题1</li>

24 <li>这是公告标题2</li>

25 <li>这是公告标题3</li>

26 <li>这是公告标题4</li>

27 </ul>

28 </li>

29 </ul>

30 </body>

31 </html>
View Code

event.stopPropagation()阻止冒泡

你可能感兴趣的:(target)