事件处理程序:
addEventListener();
document对象和所有文档元素都定义了一个名叫addEventListener()方法,使用这个方法人可以为事件目标注册事件处理程序。接收三个参数,第一是要注册处理程序的事件类型,可以是字符串或名字,但不可以带处理程序属性的on前缀。第二是指定类型的事件发生时调用的函数。第三是布尔值,一般会给这个参数为false,如果为true,那么函数将注册为捕获事件处理,并在事件不同的调度阶段调用。
使用:
IE8及以下版本不支持。
<button id='myBut'>点击</button>
var b = document.getElementById('myBut');
b.onclick = function(){
console.log(1);
}
b.onclick = function(){
console.log(2); // 点击只会打印2
}
<button id='myBut'>点击</button>
var b = document.getElementById('myBut');
b.onclick = function(){
console.log(1);
}
b.addEventListener('click'',function(){ // 事件名称不带on
console.log(2); // 1 2 都打印 而且顺序不会变
},false)
removeEventListener();
同样有三个参数。第一参数要移除的事件名,第二要移除的函数,第三默认fasle。
用法与addEventListener()相同。
attachEvent();
与addEventListener()类似,不过事件名要加on,它只有两个参数,允许相同的事件处理程序函数注册多次。
detachEvent();
与removeEventListener()类似。使用与attachEvent()相同。
事件处理程序的作用域。
定义时的作用域而非调用时的作用域中执行。因此事件处理程序想调用Window对象就必须带window,而不是直接写属性名。
事件处理程序的返回值。
返回值false就是告诉浏览器不要执行这个事件相关的默认操作。
调用顺序。
通过设置对象属性或HTML属性注册的处理程序一直优先调用。