1、事件html
2、事件流java
以上内容见:javaScript事件(一)事件流浏览器
3、事件处理程序函数
4、IE事件处理程序spa
以上内容见javaScript事件(二)事件处理程序code
事件在浏览器中是以对象的形式存在的,即event。触发一个事件,就会产生一个事件对象event,该对象包含着全部与事件有关的信息。包括致使事件的元素、事件的类型以及其余与特定事件相关的信息。htm
例如:鼠标操做产生的event中会包含鼠标位置的信息;键盘操做产生的event中会包含与按下的键有关的信息。对象
全部浏览器都支持event对象,但支持方式不一样,在DOM中event对象必须做为惟一的参数传给事件处理函数,在IE中event是window对象的一个属性。blog
<input id="btn" type="button" value="click" onclick=" console.log('html事件处理程序'+event.type)"/>
这样会建立一个包含局部变量event的函数。可经过event直接访问事件对象。事件
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>
第一种状况: 经过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>
可是我有两个地方不懂。
一、经过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 }
二、经过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>
6、事件对象的公共成员
这部份内容见javaScript事件(四)event的公共成员(属性和方法)
7、鼠标事件
这部份内容见javaScript事件(五)事件类型之鼠标事件
分类: JavaScript