新闻中心

如何实现一个J*aScript的Pub/Sub模式_j*ascript设计模式

2025-11-04
浏览次数:
返回列表
答案:通过创建事件中心实现订阅、发布和取消功能,支持模块间解耦通信。使用 events 对象存储事件与回调映射,subscribe 添加监听,publish 触发执行,unsubscribe 移除监听,并可扩展 once、通配符等特性提升实用性。

如何实现一个javascript的pub/sub模式_javascript设计模式

发布-订阅模式(Pub/Sub)是一种广泛使用的通信模式,特别适合解耦组件之间的依赖关系。在J*aScript中,它常用于事件系统、状态管理或模块间通信。实现一个轻量但功能完整的Pub/Sub系统并不复杂,核心是维护一个事件中心,支持订阅、发布和取消订阅。

定义事件中心

创建一个独立的对象或类来管理所有事件。这个中心负责存储回调函数(订阅者),并在事件触发时通知它们(发布消息)。

使用一个对象来保存事件名与对应回调函数的映射关系:

const pubSub = {

  events: {},

  // 订阅事件

  subscribe: function (event, callback) {

    if (!this.events[event]) {

      this.events[event] = [];

    }

    this.events[event].push(callback);

  },

  // 发布事件

  publish: function (event, data) {

    if (!this.events[event]) return;

    this.events[event].forEach(callback => callback(data));

  },

  // 取消订阅

  unsubscribe: function (event, callback) {

    if (!this.events[event]) return;

    this.events[event] = this.events[event].filter(cb => cb !== callback);

  }

};

使用示例

通过简单的调用即可实现模块间的松耦合通信。

// 订阅用户登录事件

Shoping购物网源码 Shoping购物网源码

该系统采用多层模式开发,这个网站主要展示女装的经营,更易于网站的扩展和后期的维护,同时也根据常用的SQL注入手段做出相应的防御以提高网站的安全性,本网站实现了购物车,产品订单管理,产品展示,等等,后台实现了动态权限的管理,客户管理,订单管理以及商品管理等等,前台页面设计精致,后台便于操作等。实现了无限子类的添加,实现了动态权限的管理,支持一下一个人做的辛苦

Shoping购物网源码 0 查看详情 Shoping购物网源码

pubSub.subscribe('userLogin', function(userData) {

  console.log('欢迎 ' + userData.name);

});

// 另一个订阅者

function logTime(data) {

  console.log('登录时间:' + new Date().toLocaleString());

}

pubSub.subscribe('userLogin', logTime);

// 发布事件

pubSub.publish('userLogin', { name: 'Alice' });

// 控制台输出:

// 欢迎 Alice

// 登录时间:2025/4/5 下午3:20:00

增强功能建议

实际项目中可扩展以下特性提升实用性:

  • 支持一次*件(once):监听器执行一次后自动移除
  • 通配符订阅:如 'user.*' 匹配所有以 user 开头的事件
  • 命名空间隔离:多个实例避免全局污染
  • 错误处理:捕获回调中的异常,防止中断其他订阅者

例如添加 once 方法:

once: function (event, callback) {

  const onceWrapper = (data) => {

    callback(data);

    this.unsubscribe(event, onceWrapper);

  };

  this.subscribe(event, onceWrapper);

}

基本上就这些。一个简洁的Pub/Sub系统能极大提升代码组织性,尤其在前端组件通信或状态变化通知场景中非常实用。关键是保持接口清晰,逻辑简单可靠。

以上就是如何实现一个J*aScript的Pub/Sub模式_j*ascript设计模式的详细内容,更多请关注其它相关文章!


# 是一种  # 招聘网站建设步骤  # 苏州寺庙网站建设  # 优化糖贴网站  # 重庆网站建设入门到精通  # 广州越秀模板网站建设  # 罗源推广营销  # 全国关键词排名前10名  # 株洲网站建设网站  # 宁都推广网络营销一体化  # 企鹅seo  # 本网站  # 子类  # 多个  # pub/sub  # 订单管理  # 移除  # 实现了  # 购物网  # 回调  # 如何实现  # 2025  # 回调函数  # app  # 前端  # java  # javascript 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 解决J*aScript中重复选择项的确认对话框显示问题  yandex入口引擎手机版 yandex安卓版下载入口  Golang如何实现简单的Web表单_Golang表单提交与验证处理方法  快手赚钱渠道_快手收益来源  限制HTML日期输入框的日期选择范围  抖音创作助手登录入口_抖音创作辅助工具官网直达  J*aScript井字棋(Tic-Tac-Toe)核心交互逻辑实现教程  sublime怎么覆盖插件的默认快捷键_sublime快捷键优先级与设置  J*aScript DOM操作:高效清空列表元素的策略与实践  在Runstone环境中高效处理TasteDive API的JSON数据  解决Flask中Quill编辑器内容提交失败及TypeError的指南  内存检查:在VS Code中调试C++时的内存视图  探索高级语言到C/C++的转译路径:以Go为例及内存管理策略  可靠CSGO开箱平台解析 CSGO开箱网合集  解决Python logging 中 datefmt 导致时间戳固定不变的问题  Excel函数批量查找替换超快方法_Excel用REPLACE和FIND函数秒级替换  C#使用XPath查询节点时出错? 常见语法错误与调试技巧  新三国志曹操传110级星符试炼夏侯渊极难攻略  微博网页版首页入口 微博电脑端官网登录链接  J*aScript map 迭代中检测空数组元素的有效方法  CSS布局:解决全屏元素100%尺寸与外边距导致的页面溢出问题  聚水潭ERP登录页面入口 聚水潭ERP官网登录界面  cad如何更改注释性对象的比例_cad注释性比例调整方法  Angular中父组件异步更新子组件复选框状态的实践指南  PS5 Pro有点优势但不多! 《燕云十六声》PS5平台与PC性能画面对比  邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧  优化LangChain文档加载与ChromaDB集成:解决多文档处理与分块问题  CSS条件样式无法按设备触发怎么排查_media条件语句正确设置解决触发问题  在J*a中如何开发简易博客标签推荐系统_博客标签推荐项目实战解析  Yandex搜索引擎官方地址 俄罗斯网络世界的主要入口  漫蛙2在线漫画入口 漫蛙正版漫画网页版直达  QQ邮箱在线登录平台 QQ邮箱个人邮箱网页版入口  J*aScript中在Map循环中检测并处理空数组元素  Python多线程中正确使用sigwait处理SIGALRM信号  如何在Promise链中有效终止错误处理后的执行  css滚动区域卡顿如何改善_css滚动问题用will-change优化渲染  手机CPU怎么影响游戏体验_手机CPU对游戏性能的影响分析  荣耀Play7T运行卡顿解决_荣耀Play7T性能优化  不同用户不同价格! 索尼开启账户个性化定价测试  c++如何使用Meson构建系统_c++比CMake更快的构建工具  Flexbox布局实践:实现粘性导航栏与底部固定页脚  Win11怎么关闭触摸屏_Windows 11禁用HID符合标准触摸屏  京东京造J1和网易云音乐氧气真无线有什么不同_国产电商蓝牙耳机音质对比  Go语言中的*string:深入理解字符串指针  Win10如何开启蓝牙功能_Windows10找不到蓝牙开关解决方法  离线运行Go语言之旅:本地部署与GOPATH配置指南  抖音网页版平台入口 抖音网页版官网在线访问教程  利用Bokeh CustomJS动态控制DataTable列可见性  QQ邮箱官方网页版登录 QQ邮箱个人邮箱快速访问  免费抖音短视频入口_抖音网页版短视频免费通道 

搜索