码迷,mamicode.com
首页 > Web开发 > 详细

jQuery中event.target和this的区别

时间:2016-07-06 20:18:27      阅读:252      评论:0      收藏:0      [点我收藏+]

标签:

this和event.target的区别:

  1.js中事件是会冒泡的,所以this是可以变化的,但event.target不会变化,它永远指向触发事件的DOM元素本身;

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

比如,一个很简单的例子.

$(event.target)指向触发事件的元素. 当点击蓝色小方框时, 蓝色小方框会变成橙色, 但其外围的大方框不会变色, 即没有触发事件的冒泡行为.

 

   点击前:   技术分享    点击后:       技术分享

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="UTF-8">
 5         <title></title>
 6         <style type="text/css">
 7           *{
 8               margin: 0;
 9               padding: 0;
10              }
11             #big {
12                 width: 200px;
13                 height: 200px;
14                 background-color: gray;                
15             }    
16             #small {
17                 width: 100px;
18                 height: 100px;
19                 background-color: blue;
20                 margin: 0 auto;
21             }
22         </style>        
23     </head>
24     <body>
25     <div id="big">
26         <div id="small"></div>
27     </div>
28     <script src="js/jquery-2.2.4.min.js" type="text/javascript" charset="utf-8"></script>
29     <script type="text/javascript">
30         $("div, input").click(function (event) {
31              $(event.target).css("background-color", "orange");
32         });
33     </script>
34     </body>
35 </html>

$(this)指向触发事件的元素. 当点击蓝色小方框时,蓝色小方框会变橙色, 同时其外围的灰色大方框也会变成橙色, 也就是说当用this获取触发事件的元素会引起事件的冒泡.

   点击前:    技术分享     点击后:    技术分享

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="UTF-8">
 5         <title></title>
 6         <style type="text/css">
 7           *{
 8               margin: 0;
 9               padding: 0;
10             }
11             #big {
12                 width: 200px;
13                 height: 200px;
14                 background-color: gray;                
15             }    
16             #small {
17                 width: 100px;
18                 height: 100px;
19                 background-color: blue;
20                 margin: 0 auto;
21             }
22         </style>        
23     </head>
24     <body>
25     <div id="big">
26         <div id="small"></div>
27     </div>
28     <script src="js/jquery-2.2.4.min.js" type="text/javascript" charset="utf-8"></script>
29     <script type="text/javascript">
30         $("div, input").click(function () {        
31             $(this).css("background-color", "orange");
32         })
33     </script>
34     </body>
35 </html>

 

jQuery中event.target和this的区别

标签:

原文地址:http://www.cnblogs.com/hhsy/p/5647930.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!