标签:opt 订阅 obj addUser 模式 userList 发布 key
人物:订阅者,发布者 订阅者:添加订阅者,存储订阅者 发布者:发布信息1.添加订阅者,创建同类型容器(数组),存储同类型订阅者,同时将回调传入数组 2.发布者获取不同类型的容器(数组),进行循环,然后调用其回调,进行发布 const obj = { // 存储订阅者 userList: {},
// 添加订阅者 addUser (key, callBack) { const { userList } = this // 解构存储订阅者列表
if (!userList[key]) { // 对不同类型的订阅者进行分类 userList[key] = [] }
userList[key].push(callBack) // 订阅者传入的回调放入数组 },
// 发布者,给订阅者发布信息 publish (key, opt) { const arr = this.userList[key] // 获取订阅者列表 arr.forEach(item => { // 循环每一名订阅者的回调,进行调用(发布) item(opt) }) } }
// 添加订阅者 obj.addUser('m20', opt => { console.log('小白:', opt) })
obj.addUser('m20', opt => { console.log('小黑:', opt) })
obj.addUser('m40', opt => { console.log('小黄:', opt) })
// 订阅者发布信息 obj.publish('m20', '1000万')
obj.publish('m40', '2000万')
标签:opt,订阅,obj,addUser,模式,userList,发布,key 来源: https://www.cnblogs.com/fengxiana/p/13256538.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。