JavaScript事件学习小结(三)js事件对象

 更新时间:2016年06月09日 11:51:29   作者:starof  
这篇文章主要介绍了JavaScript事件学习小结(三)js事件对象的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下

相关阅读:

JavaScript事件学习小结(五)js中事件类型之鼠标事件

https://www.jb51.net/article/86259.htm

JavaScript事件学习小结(一)事件流

https://www.jb51.net/article/86261.htm

javaScript事件学习小结(四)event的公共成员(属性和方法)

https://www.jb51.net/article/86262.htm

JavaScript事件学习小结(二)js事件处理程序

https://www.jb51.net/article/86264.htm

JavaScript事件学习小结(三)js事件对象

https://www.jb51.net/article/86266.htm

一、事件对象

1、认识事件对象

事件在浏览器中是以对象的形式存在的,即event。触发一个事件,就会产生一个事件对象event,该对象包含着所有与事件有关的信息。包括导致事件的元素、事件的类型以及其他与特定事件相关的信息。

例如:鼠标操作产生的event中会包含鼠标位置的信息;键盘操作产生的event中会包含与按下的键有关的信息。

所有浏览器都支持event对象,但支持方式不同,在DOM中event对象必须作为唯一的参数传给事件处理函数,在IE中event是window对象的一个属性。

2、html事件处理程序中event

<input id="btn" type="button" value="click" onclick=" console.log('html事件处理程序'+event.type)"/>

这样会创建一个包含局部变量event的函数。可通过event直接访问事件对象。

3、DOM中的事件对象

DOM0级和DOM2级事件处理程序都会把event作为参数传入。

<body>
<input id="btn" type="button" value="click"/>
<script>
var btn=document.getElementById("btn");
btn.onclick=function(event){
console.log("DOM0 & click");
console.log(event.type); //click
}
btn.addEventListener("click", function (event) {
console.log("DOM2 & click");
console.log(event.type); //click
},false);
</script>
</body>

4、IE中的事件对象

第一种情况: 通过DOM0级方法添加事件处理程序时,event对象作为window对象的一个属性存在。

<body>
<input id="btn" type="button" value="click"/>
<script>
var btn=document.getElementById("btn");
btn.onclick= function () {
var event=window.event;
console.log(event.type); //click
}
</script>
</body>

第二种情况:通过attachEvent()添加的事件处理程序,event对象作为参数传入。

<body>
<input id="btn" type="button" value="click"/>
<script>
var btn=document.getElementById("btn");
btn.attachEvent("onclick", function (type) {
console.log(event.type); //click
})
</script>
</body>

但是我有两个地方不懂。

1、通过DOM0级方法添加的事件处理程序中同样可以传入一个event参数,它的type和window.event.type一样,但是传入的event参数却和window.event不一样,为什么?

btn.onclick= function (event) {
var event1=window.event;
console.log('event1.type='+event1.type); //event1.type=click
console.log('event.type='+event.type); //event.type=click
console.log('event1==event?'+(event==event1)); //event1==event?false
}

2、通过attachEvent添加的事件处理程序中传入的event和window.event是不一样的,为什么?

<body>
<input id="btn" type="button" value="click"/>
<script>
var btn=document.getElementById("btn");
btn.attachEvent("onclick", function (type) {
console.log(event.type); //click
console.log("event==window.event?"+(event==window.event)); //event==window.event?false
})
</script>
</body>

以上所述是小编给大家介绍的JavaScript事件学习小结(三)js事件对象的相关知识,希望对大家有所帮助,如果大家想了解更多内容敬请关注脚本之家网站!

相关文章

  • javascript 用局部变量来代替全局变量

    javascript 用局部变量来代替全局变量

    在JavaScript中,我们应该尽可能的用局部变量来代替全局变量,这句话所有人都知道,可是这句话是谁先说的?
    2009-05-05
  • JavaScript设置获取和设置属性的方法

    JavaScript设置获取和设置属性的方法

    这篇文章主要介绍了JavaScript设置获取和设置属性的方法,学会使用getAttribute、setAttribute的用法,需要的朋友可以参考下
    2015-03-03
  • js注入 黑客之路必备!

    js注入 黑客之路必备!

    这篇文章主要为大家详细介绍了js注入,黑客之路必备!本文告诉大家什么是js注入,如何进行js注入攻防,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 移动端js触摸事件详解

    移动端js触摸事件详解

    这篇文章主要为大家详细介绍了移动端js触摸事件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 小程序采集录音并上传到后台

    小程序采集录音并上传到后台

    这篇文章主要为大家详细介绍了小程序采集录音并上传到后台,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • JS解决Date对象在IOS中的“大坑” 以及时间格式兼容问题

    JS解决Date对象在IOS中的“大坑” 以及时间格式兼容问题

    这篇文章主要介绍了JS解决Date对象在IOS中的“大坑” 以及时间格式兼容问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 详解开源的JavaScript插件化框架MinimaJS

    详解开源的JavaScript插件化框架MinimaJS

    这篇文章主要介绍了开源的JavaScript插件化框架MinimaJS的详解,详细的介绍了MinimaJS的使用,具有一定的参考价值,有兴趣的可以了解一下
    2017-10-10
  • 学习Javascript面向对象编程之封装

    学习Javascript面向对象编程之封装

    这篇文章主要帮助大家学习Javascript面向对象编程之封装,由浅入深的介绍了封装的概念定义,感兴趣的小伙伴们可以参考一下
    2016-02-02
  • js常见遍历操作小结

    js常见遍历操作小结

    这篇文章主要介绍了js常见遍历操作,结合实例形式分析了javascript for循环、for in、for each、each及map遍历简单操作技巧,需要的朋友可以参考下
    2019-06-06
  • js实现网页多级级联菜单代码

    js实现网页多级级联菜单代码

    这篇文章主要介绍了js实现网页多级级联菜单代码,涉及javascript基于数组动态构造多级级联菜单的技巧,非常具有实用价值,需要的朋友可以参考下
    2015-08-08

最新评论