【发布时间】:2019-02-27 21:02:32
【问题描述】:
使用 Java Script 中的发布/订阅者模式,例如,如果发布者发布了一个事件并且该事件有 3 个订阅者,那么如果一个订阅者需要一个“某个值”的参数来完成它的工作而另一个订阅者需要一个“某个值”的参数,那么该怎么办?订户需要和“一些不同的价值”的论点来完成它的工作等?
所以 'func1'、'func2' 和 'func3' 将在按钮点击事件发布时触发。每个 'func' 都需要一个唯一的参数。此按钮点击代码只是示例。
let events = {},
subUid = -1;
let pubsub = {
subscribe : function(evt, func, args) {
if (!events[evt]) {
events[evt] = [];
};
let token = (++subUid).toString();
events[evt].push({
token : token,
func : func
});
return token;
},
unsubscribe : function(token) {
for (let m in events) {
if (events[m]) {
for (let i = 0, j = events[m].length; i < j; i++) {
if (events[m][i].token === token) {
events[m].splice( i, 1 );
return token;
};
};
};
};
return this;
},
publish : function(evt, args) {
if (!events[evt]) {
throw ''+evt+' doesn\'t exist!';
};
const subscribers = events[evt];
const len = (subscribers) ? subscribers.length : 0;
for (let i = 0; i < len; i++) {
subscribers[i].func(evt, args); // What to do here??!
};
return this;
}
};
/* ------------------- 实现 -------- */
$('#myButton').on('click', this, function(event) {
let someVal = [2, 3, 4];
someHandler(someVal);
});
const func1 = (evt, someVal)=> {
let total = someVal * 5;
console.log(total);
},
func2 = (evt, someDifferentVal)=> {
let total = someDifferentVal * 10;
console.log(total);
},
func3 = (evt, anotherDifferentVal)=> {
let total = anotherDifferentVal * 15;
console.log(total);
};
let subscription1 = pubsub.subscribe('newEventA', func1),
subscription2 = pubsub.subscribe('newEventA', func2),
subscription3 = pubsub.subscribe('newEventA', func3);
let someHandler = (args)=> {
pubsub.publish('newEventA', args);
};
【问题讨论】:
-
您能详细说明一下吗?发布代码 sn-p 或给出某种示例。你到底想达到什么目的?
标签: javascript parameters unique publish-subscribe