原生js实现的观察者和订阅者模式简单示例
程序员文章站
2022-03-20 17:45:41
本文实例讲述了原生js实现的观察者和订阅者模式。分享给大家供大家参考,具体如下:观察者模式也叫 发布者-订阅者模式,发布者发布事件,订阅者监听事件并做出反应在传统的前端解耦方面,观察者模式作为比较常见...
本文实例讲述了原生js实现的观察者和订阅者模式。分享给大家供大家参考,具体如下:
观察者模式也叫 发布者-订阅者模式,发布者发布事件,订阅者监听事件并做出反应
在传统的前端解耦方面,观察者模式作为比较常见一种设计模式,大量使用在各种框架类库的设计当中。
核心代码:
// eventproxy.js 'use strict'; const eventproxy = { onobj: {}, oneobj: {}, on: function(key, fn) { if(this.onobj[key] === undefined) { this.onobj[key] = []; } this.onobj[key].push(fn); }, one: function(key, fn) { if(this.oneobj[key] === undefined) { this.oneobj[key] = []; } this.oneobj[key].push(fn); }, off: function(key) { this.onobj[key] = []; this.oneobj[key] = []; }, trigger: function() { let key, args; if(arguments.length == 0) { return false; } key = arguments[0]; args = [].concat(array.prototype.slice.call(arguments, 1)); if(this.onobj[key] !== undefined && this.onobj[key].length > 0) { for(let i in this.onobj[key]) { this.onobj[key][i].apply(null, args); } } if(this.oneobj[key] !== undefined && this.oneobj[key].length > 0) { for(let i in this.oneobj[key]) { this.oneobj[key][i].apply(null, args); this.oneobj[key][i] = undefined; } this.oneobj[key] = []; } } }; export default eventproxy;
使用:引入全局事件类,或通过配置webpack将事件类设置为全局变量
import { eventproxy } from '@/utils' class parent extends component{ render() { return ( <div style={{margintop:"50px"}}> <child_1/> <child_2/> </div> ); } } // componentdidupdate 与 render 方法与上例一致 class child_1 extends component{ componentdidmount() { settimeout(() => { // 发布 msg 事件 console.log(eventproxy) eventproxy.trigger('msg', 'end','lll'); }, 5000); } render() { return ( <div>我是组件一</div> ) } } // componentdidupdate 方法与上例一致 class child_2 extends component{ state = { msg: 'start' }; componentdidmount() { // 监听 msg 事件 eventproxy.on('msg', (msg,mm) => { console.log(msg,mm) this.setstate({ msg:msg }); }); } render() { return <div> <p>child_2 component: {this.state.msg}</p> </div> } }
参考:淘宝前端团队技术库
感兴趣的朋友可以使用在线html/css/javascript代码运行工具:http://tools.jb51.net/code/htmljsrun测试上述代码运行效果。