今天在看javascript入门经典-事件一章中看到了 this 和 event 两种传参形式。因为作为一个初级的前端开发人员平时只用过 this传参,so很想弄清楚,this和event的区别是什么,什么情况下用什么比较合适。

  onclick = changeImg(this)       vs     onclick = changeImg(event)

<img src='usa.gif' onclick="changeImg(event)" />
<script>
  var myImages = [
    'usa.gif','canada.gif','jamaica.gif','mexico.gif'
  ];
  function changeImg(e) {
    var el = e.target;
    var newImgNumber = Math.round(Math.round()*3);
    while(el.src.indexOf(myImages[newImgNumber]) != -1){
      el.src =myImages[newImgNumber];
    }
  }
</script>
  1. this是Javascript语言的一个关键字。

  2. this代表函数运行时,自动生成的一个内部对象,只能在函数内部使用。

  3. this和event.target的区别:

    js中事件是会冒泡的,所以this是可以变化的,但event.target不会变化(在事件触发时,只传递当前event对象的引用),它永远是直接接受事件的目标DOM元素;

  另外,this和event.target都是dom对象,如果要使用jquey中的方法可以将他们转换为jquery对象:$(this)和$(event.target);

  今天(2017/12/06)发现了更详细的讲解,有使用过程中的详细介绍,需要的小伙伴们可以自行查看:jquery 关于event.target使用的几点说明介绍

最新文章

  1. VS2010中dll不可用问题
  2. 解决web中的乱码
  3. JavaScript深入浅出2-表达式和运算符
  4. [转]JVM内存堆布局图解分析
  5. [ACM_搜索] ZOJ 1103 || POJ 2415 Hike on a Graph (带条件移动3盘子到同一位置的最少步数 广搜)
  6. Eclipse使用Jetty(转)
  7. branch
  8. VS2015安装开发ios android
  9. Pawn Brotherhood
  10. JAVA网络编程-----TCP沟通
  11. Appium Android Bootstrap源码分析之简介
  12. 你有什么理由还不选择阿里云服务器呢--从阿里云发布自研商用关系型数据库POLARDB想到的
  13. 在docker上部署mysql
  14. Java编程思想 学习笔记2
  15. MyEclipse2014安装插件的几种方式(适用于Eclipse或MyEclipse其他版本)
  16. 萌新程序媛的首个作品,基于NoSQL的内容管理及低码开发平台
  17. [转载]Ubuntu下Git服务器安装与配置
  18. 在vue中子组件修改props引发的对js深拷贝和浅拷贝的思考
  19. C# 特性(Attribute)(一)
  20. Django学习笔记 Django的工程目录

热门文章

  1. NTKO在线office控件使用实例
  2. POJ3977 Subset 折半枚举
  3. golang time.Duration()的问题解疑
  4. MapReduce Cross 示例
  5. 第二天,初步slide第一版和家的照片墙
  6. linux 经常使用网络命令
  7. 告诉大家我是如何在14:00秒杀到 《深入理解Bootstrap》
  8. 【bzoj1452】[JSOI2009]Count
  9. mongodb配置复制集replset
  10. HDU 5976 Detachment 【贪心】 (2016ACM/ICPC亚洲区大连站)