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

相关阅读:

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

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

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

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

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

一、事件对象

1、认识事件对象

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

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

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

2、HTML事件处理程序中event

rush:js;"> HTML事件处理程序'+event.type)"/>

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

3、DOM中的事件对象

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

rush:js;"> 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);

4、IE中的事件对象

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

rush:js;"> var btn=document.getElementById("btn"); btn.onclick= function () { var event=window.event; console.log(event.type); //click }

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

rush:js;"> var btn=document.getElementById("btn"); btn.attachEvent("onclick",function (type) { console.log(event.type); //click })

但是我有两个地方不懂。

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

rush:js;"> 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是不一样的,为什么?

rush:js;"> 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 })

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

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...