引言
EventTarget 是一个 DOM 接口,由可以接收事件、并且可以创建侦听器的对象实现。 是最常见的 event targets ,但是其他对象也可以作为 event targets,比如 XMLHttpRequest、AudioNode、AudioContent等等。
许多 event targets (包括 elements, documents 和 windows)支持通过 onevent 特性和属性设置事件处理程序 。
一、构造函数
EventTarget()
创建一个新的EventTarget对象实例。
二、方法
-
EventTarget.addEventListener()在EventTarget上注册特定事件类型的事件处理程序。
-
EventTarget.removeEventListener()EventTarget中删除事件侦听器。
将事件分派到此EventTarget。
三、示例
EventTarget的简单实现
var EventTarget = function () {
this.listeners = {};
};
EventTarget.prototype.listeners = null;
EventTarget.prototype.addEventListener = function (type, callback) {
if (!(type in this.listeners)) {
this.listeners[type] = [];
}
this.listeners[type].push(callback);
};
EventTarget.prototype.removeEventListener = function (type, callback) {
if (!(type in this.listeners)) {
return;
}
var stack = this.listeners[type];
for (var i = 0, l = stack.length; i < l; i++) {
if (stack[i] === callback) {
stack.splice(i, 1);
return this.removeEventListener(type, callback);
}
}
};
EventTarget.prototype.dispatchEvent = function (event) {
if (!(event.type in this.listeners)) {
return;
}
var stack = this.listeners[event.type];
event.target = this;
for (var i = 0, l = stack.length; i < l; i++) {
stack[i].call(this, event);
}
};
EventTarget.prototype.dispatchEvent = function(event) {
if(!(event.type in this.listeners)) {
return
}
var stack = this.listeners[event.type];
event.target = this;
for(var i=0;i<stack.length;i++) {
stack[i].call(this,event)
}
}