(三十四)设计模式之发布订阅模式

本文介绍了一种常见的软件设计模式——发布订阅模式,并通过一个具体的JavaScript实现案例进行详细解析。该模式允许对象之间进行解耦通信,提高代码的可维护性和扩展性。
/** * 发布订阅模式 */ 
var EventCenter = (function(){ 
    var events = {}; 
/* { my_event: [{handler: function(data){xxx}}, {handler: function(data){yyy}}] } */ 
// 绑定事件 添加回调 
function on(evt, handler){ 
    events[evt] = events[evt] || []; 
    events[evt].push({ handler:handler }) 
} 
function fire(evt, arg){ 
    if(!events[evt]){ return } 
    for(var i=0; i < events[evt].length; i++){ 
        events[evt][i].handler(arg); 
    } 
} 
function off(evt){ delete events[evt]; } 
    return { on:on, fire:fire, off:off } 
}()); 
var number = 1; 
EventCenter.on('click', function(data){ 
    console.log('click 事件' + data + number++ +'次'); 
}); 
EventCenter.off('click'); 
// 只绑定一次 
EventCenter.on('click', function(data){ 
    console.log('click 事件' + data + number++ +'次'); 
}); 
EventCenter.fire('click', '绑定');

  

來源:简书
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值