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

  • 相关阅读:
    mysql错误Error(1133): Can’t find any matching row in the use
    xtrbackup备份mysql
    配置Mysql审计
    Mysql:sql语句
    mysql基准测试与sysbench工具
    tomcat排错以及优化
    nginx反向代理
    Nginx
    服务器归分第一篇
    Android安装BusyBox(三星N7108)
  • 原文地址:https://www.cnblogs.com/MissBean/p/4300894.html
Copyright © 2020-2023  润新知