Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 | 1x 1x 3x 3x 3x 2x 1x 4x 1x 3x 1x 4x 4x 4x 4x 3x 1x | /**
* 广播组件
* - 构造实例时,需要传入事件白名单列表。
* - 只有在白名单列表上的事件才可以被触发。
* - 事件添加,移除,激发的调用方法参考 Events。
* @see [evt/Events](#evt-events)
* @class evt/Listener
* @example
* @example
* var $listener = require('@spore-ui/kit/packages/evt/listener');
*
* // 白名单里只记录了 event1 事件
* var channelGlobal = new $listener([
* 'event1'
* ]);
* channelGlobal.on('event1', function(){
* console.log('event1');
* });
* channelGlobal.on('event2', function(){
* // will not run
* console.log('event2');
* });
* channelGlobal.trigger('event1');
* channelGlobal.trigger('event2');
*/
var $events = require('./events');
var Listener = function (events) {
this.privateWhiteList = {};
this.privateReceiver = new $events();
if (Array.isArray(events)) {
events.forEach(this.define.bind(this));
}
};
Listener.prototype = {
constructor: Listener,
/**
* 在白名单上定义一个事件名称
* @method Listener#define
* @memberof evt/Listener
* @param {String} eventName
*/
define: function (eventName) {
this.privateWhiteList[eventName] = true;
},
/**
* 移除白名单上定义的事件名称
* @method Listener#undefine
* @memberof evt/Listener
* @param {String} eventName
*/
undefine: function (eventName) {
delete this.privateWhiteList[eventName];
},
/**
* 广播组件绑定事件
* @see [Events#on](#events-on)
* @method Listener#on
* @memberof evt/Listener
* @param {String} eventName 要绑定的事件名称
* @param {Function} fn 要绑定的事件回调函数
*/
on: function () {
this.privateReceiver.on.apply(this.privateReceiver, arguments);
},
/**
* 广播组件移除事件
* @see [Events#off](#events-off)
* @method Listener#off
* @memberof evt/Listener
* @param {String} eventName 要移除绑定的事件名称
* @param {Function} fn 要移除绑定的事件回调函数
*/
off: function () {
this.privateReceiver.off.apply(this.privateReceiver, arguments);
},
/**
* 广播组件派发事件
* @see [Events#trigger](#events-trigger)
* @method Listener#trigger
* @memberof evt/Listener
* @param {String} eventName 要触发的事件名称
* @param {...*} [arg] 事件参数
*/
trigger: function (events) {
var rest = [].slice.call(arguments, 1);
// 按照Events.trigger的调用方式,第一个参数是用空格分隔的事件名称列表
events = events.split(/\s+/);
// 遍历事件列表,依据白名单决定事件是否激发
events.forEach(function (evtName) {
if (this.privateWhiteList[evtName]) {
this.privateReceiver.trigger.apply(this.privateReceiver, [evtName].concat(rest));
}
}.bind(this));
},
};
module.exports = Listener;
|