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>
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>
event.stopPropagation()阻止冒泡