当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 基于js中this和event 的区别(详解)

基于js中this和event 的区别(详解)

2017年12月12日  | 移动技术网IT编程  | 我要评论

今天在看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);

以上这篇基于js中this和event 的区别(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网