EventTarget

197 阅读1分钟

引言

EventTarget 是一个 DOM 接口,由可以接收事件、并且可以创建侦听器的对象实现。 是最常见的 event targets ,但是其他对象也可以作为 event targets,比如 XMLHttpRequestAudioNodeAudioContent等等。

许多 event targets (包括 elements, documents 和 windows)支持通过 onevent 特性和属性设置事件处理程序 。

一、构造函数

EventTarget()

创建一个新的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)
    }
}