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

时间: 2024-10-12 20:06:54

js中event.target,this的相关文章

jQuery中event.target和this的区别

this和event.target的区别: 1.js中事件是会冒泡的,所以this是可以变化的,但event.target不会变化,它永远指向触发事件的DOM元素本身: 2.this和event.target都是dom对象,使用jQuey中的方法可以将他们转换为jquery对象:$(this)和$(event.target). 比如,一个很简单的例子. $(event.target)指向触发事件的元素. 当点击蓝色小方框时, 蓝色小方框会变成橙色, 但其外围的大方框不会变色, 即没有触发事件的冒

js中的target与currentTarget的区别&lt;转&gt;

关于js中target与currentTarget的区别的关键在于他们所处在的事件流的阶段是不一样的,target处于事件流的目标阶段,currentTarget处理事件流的捕获.处于目标阶段和冒泡阶段.只有当他们同事处于目标阶段的时候他们的指向才是一样的,请看以下代码: <!DOCTYPE HTML> <html> <head> <meta charset="utf-8" /> <title>js性能优化</title

js事件 event.target

我们购物车里,会时不时增加和删除产品时,就会绑定事件和解绑的动作. <ul> <li></li> <li></li> </ul> 例子:在li上未来绑定事件, $('ul').on('click','li',function(){ $(this).remove(); }); 例子:在ul上绑定事件 $('ul').on('click',function(event){ var This=event.target; $(This).re

关于js中event的target和currentTarget的区别

今天又遇到这个问题了,总是搞不清楚target和currentTarget的区别,百度搜索的时候看到一遍文章解释得很清楚,特意记录下录,以备不时之需: target与currentTarget的区别? 通俗易懂的说法: 比如说现在有A和B, A.addChild(B) A监听鼠标点击事件 那么当点击B时,target是B,currentTarget是A 也就是说,currentTarget始终是监听事件者,而target是事件的真正发出者 总结: target在事件流的目标阶段:currentT

js中event.keyCode用法及keyCode对照表

HTML 用户名:<input type="text" id="UserAccount" onKeyPress="JumpByEnter(UserPwd)" /> 密码:<input name="UserPwd" type="password" onKeyPress="IsEnterKeyPress()"> JavaScript: JumpByEnter(User

JS中event事件

JS事件基础 1.event对象 (1)用来获取事件的详细信息:鼠标位置.键盘位置 document的本质:document.childNodes[0].tagName     例子:获取鼠标位置:clientX横坐标,clientY纵坐标 代码如下: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script>

js中event事件处理

1. HTML事件 ?直接添加到HTML结构中 function show() { alert('hello'); } <body> <button id="btn" onclick="show()">按钮</button> </body> 2. DOM0级事件 ?把一个函数赋值给一个事件处理程序 ? ? a. 移除事件:event.onclick = null ? ? b. dom 0级事件只允许绑定一个事件处理函数

在javascript中event的target和currentTarget的区别

JavaScript的event对象中 event.target指代的是:触发事件的元素 event.currentTarget指代的是:事件绑定的元素 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div

在js自定义函数中使用$(event.target)代替$(this)

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <ti