zoukankan      html  css  js  c++  java
  • 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)指向触发事件的元素. 当点击蓝色小方框时, 蓝色小方框会变成橙色, 但其外围的大方框不会变色, 即没有触发事件的冒泡行为.

       点击前:       点击后:      

     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                  200px;
    13                 height: 200px;
    14                 background-color: gray;                
    15             }    
    16             #small {
    17                  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                  200px;
    13                 height: 200px;
    14                 background-color: gray;                
    15             }    
    16             #small {
    17                  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>
  • 相关阅读:
    「疫期集训day11」沙漠
    「树形DP」洛谷P2607 [ZJOI2008]骑士
    「疫期集训day10」玫瑰
    「疫期集训day9」七月
    核心容器(概念)
    初识Spring
    IOC(控制反转思想)原型理论推导
    图片在上,文字在下并且等间距的三个菜单按钮
    编写登陆接口
    001使用gltf创建3d模型
  • 原文地址:https://www.cnblogs.com/hhsy/p/5647930.html
Copyright © 2011-2022 走看看