每个事件函数天生有一个参数叫event,它是事件对象,如果想修改event的名称,事件函数的第一个参数就是用来修改的

<div id="div"></div>
var oDiv = document.getElementById("div");
oDiv.onclick = function() {
    console.dir(arguments);
};
document.body.onclick = function(e) {
    console.dir(e);  //MouseEvent

当我们触发#div的点击行为的时候,会执行对应绑定的方法

不仅仅把绑定的方法执行了,而且浏览器还默认的给这个方法传递了一个参数值,叫做MouseEvent,叫做鼠标事件对象,是一个对象属性类型的值

var e = evt || event;
  1. event 使用前提,必须有事件 不同的对象产生的事件不同
  2. event 代表事件的状态,例如触发event对象的元素、鼠标的位置及状态、按下的键等等。
  3. event 对象只在事件发生的过程中才有效。
  4. event 的某些属性只对特定的事件有意义。比如,fromElementtoElement属性只对onmouseoveronmouseout事件有意义。

传进来这个e,在iE9以上才有

在IE6,7,8时,e是不会传进去的

window.event谷歌下也有,IE6,7,8下也有,但是火狐下没有window.event

所以IE6,7,8下只能用window.event

而IE9,谷歌,火狐等标准浏览器,e都是可以用的

 oDiv.onclick = function (e) {
     console.dir(e);
  //->IE6,7,8下是存在window.event里面的
     console.dir(window.event);
  }

发表回复