Javascript dispatchEvent

时间:2010-02-13 00:00:27

标签: javascript javascript-events dispatcher

嘿......我经常使用Flash,我的类使用EventDispatcher类,允许我定义类的自定义事件。我怎么能在javascript中做到这一点。

我想做这样的事情:

var MyClass = function() {
};
MyClass.prototype = {
  test : function() {
    dispatchEvent('ON_TEST');
  }
};

var mc = new MyClass();
mc.addEventListener('ON_TEST', handler);
function handler() { alert('working...') }

这与Javascript有什么关系?

1 个答案:

答案 0 :(得分:20)

要自己动手。这只是一种方式。

var MyClass = function() {
    this._events = {};
};
MyClass.prototype = {
  addListener: function(eventName, callback) {
      var events = this._events,
          callbacks = events[eventName] = events[eventName] || [];
      callbacks.push(callback);
  },
  raiseEvent: function(eventName, args) {
      var callbacks = this._events[eventName];
      for (var i = 0, l = callbacks.length; i < l; i++) {
          callbacks[i].apply(null, args);
      }
  },
  test : function() {
    this.raiseEvent('ON_TEST', [1,2,3]); // whatever args to pass to listeners
  }
};

您可能还应该添加一个'removeListener',它必须在数组中找到回调并将其从数组中删除(或者,如果没有给出回调,则可能删除整个事件的所有侦听器。)