当前位置: 首页 > news >正文

做响应式网站的价格b2b电子商务平台排名

做响应式网站的价格,b2b电子商务平台排名,html代码分享,农家乐网站建设发布订阅模式是什么 发布订阅模式是一种代码的设计模式,它允许对象间进行松散耦合的通信。 发布者(Publishers)不会直接调用订阅者(Subscribers),相反,它们通过事件通道发布消息;订…

发布订阅模式是什么

发布订阅模式是一种代码的设计模式,它允许对象间进行松散耦合的通信。
发布者(Publishers)不会直接调用订阅者(Subscribers),相反,它们通过事件通道发布消息;订阅者通过注册监听事件通道上的消息来做出响应。
这种模式在事件驱动编程和异步编程中非常有用。

发布订阅模式怎么实现

发布订阅模式在前端开发中有广泛的应用。例如,事件处理、状态管理库(如 Redux)、消息中间件、数据流控制等

1)一个用于存储事件及其对应回调的事件中心。

2)一个 on 方法,用于订阅某个事件,并将回调函数注册到事件中心中。

3)一个 emit 方法,用于发布某个事件,并调用所有订阅该事件的回调函数。

4)一个 off 方法,用于解除订阅。

使用场景:
发布-订阅模式可用于解耦复杂的代码逻辑,例如:
浏览器中的事件处理(如点击,输入等);
背景任务和前台任务之间的通信;
多模块或组件之间的通信。

高级实现:
在实际开发中,我们可能会用到一些更复杂的发布-订阅库比如 EventEmitter (Node.js 内置)、PubSubJS 等,这些库提供了更具备鲁棒性的实现和更多特性。

代码

let eventEmitter ={//事件中心events:{},//订阅事件on: function (eventName,callback){//如果事件不存在if(!this.events[eventName]){this.events[eventName] = [];}this.events[eventName].push(callback);},//发布事件 事件触发emit:function (eventName,...args){// 事件不存在if(!this.events[eventName]){return ;}this.events[eventName].forEach(callback =>{callback(...args)})},//取消事件off:function (eventName,callback){if(this.events[eventName]){this.events[eventName] = this.events[eventName].filter(e=>e!==callback)}},/*** 这里的 args 并没有在 once 函数的参数列表中明确声明,* 而是作为 onceWrapper 函数的一个内部变量(通过剩余参数语法捕获)。* 这是因为 onceWrapper 函数不知道它会接收多少个参数,* 所以它使用 ...args 来捕获所有参数,并将它们作为一个数组处理* 。然后,它可以通过 callback(...args) 将这些参数传递给 callback 函数*///一次性订阅once:function (eventName,callback){const onceWrapper = (...args)=>{callback(...args)//执行一次后取消订阅this.off(eventName,onceWrapper)}this.on(eventName,onceWrapper)}}//示例
//用户定义的回调函数
function user1(msg){console.log("user1 ",msg);
}function user2(msg){console.log("user2 ",msg);
}function user3(msg){console.log("user3 ",msg);}
//注册事件
eventEmitter.on("test",user1)
eventEmitter.on("test",user2)//事件触发
eventEmitter.emit("test","这是一个测试")//取消订阅
eventEmitter.off('test', user1);// 发布
eventEmitter.emit('test', '这次只有 User2 收到消息');//一次性订阅注册
eventEmitter.once("once",user3)//事件触发两次
eventEmitter.emit("once","test by user3")
eventEmitter.emit("once","test by user3")//没有输出

文章转载自:
http://dinncomacrosegment.tpps.cn
http://dinncopiddling.tpps.cn
http://dinncoantimonate.tpps.cn
http://dinncomatriculand.tpps.cn
http://dinncophilotechnical.tpps.cn
http://dinncoclu.tpps.cn
http://dinncosling.tpps.cn
http://dinncoskandalon.tpps.cn
http://dinncoeliminant.tpps.cn
http://dinncocardamine.tpps.cn
http://dinncooverdrink.tpps.cn
http://dinncotortoise.tpps.cn
http://dinncogonna.tpps.cn
http://dinncosliceable.tpps.cn
http://dinncoconservatorship.tpps.cn
http://dinncospacewoman.tpps.cn
http://dinncorumpelstiltskin.tpps.cn
http://dinncopneumatism.tpps.cn
http://dinncostalinabad.tpps.cn
http://dinncowoosh.tpps.cn
http://dinncoruskinian.tpps.cn
http://dinncoteutonization.tpps.cn
http://dinncothermonuke.tpps.cn
http://dinncoturbofan.tpps.cn
http://dinncomattess.tpps.cn
http://dinncobridgehead.tpps.cn
http://dinncosnazzy.tpps.cn
http://dinncobattue.tpps.cn
http://dinncohumanitarianism.tpps.cn
http://dinncosupernaculum.tpps.cn
http://dinncocassocked.tpps.cn
http://dinncoavt.tpps.cn
http://dinncomarch.tpps.cn
http://dinncosaxon.tpps.cn
http://dinncohif.tpps.cn
http://dinncoradiothorium.tpps.cn
http://dinncoclinometer.tpps.cn
http://dinncoconsecutive.tpps.cn
http://dinnconestling.tpps.cn
http://dinncolevitron.tpps.cn
http://dinncopurveyor.tpps.cn
http://dinncobobbysoxer.tpps.cn
http://dinncohalfbeak.tpps.cn
http://dinncoundulatory.tpps.cn
http://dinncopan.tpps.cn
http://dinncoapparatus.tpps.cn
http://dinncoperpendicularly.tpps.cn
http://dinncoosteophyte.tpps.cn
http://dinncoemesis.tpps.cn
http://dinncomajlis.tpps.cn
http://dinncotroposcatter.tpps.cn
http://dinncoaphis.tpps.cn
http://dinncomarage.tpps.cn
http://dinncoclotho.tpps.cn
http://dinncoacidaemia.tpps.cn
http://dinncointerlope.tpps.cn
http://dinncoroentgenograph.tpps.cn
http://dinncopromoter.tpps.cn
http://dinncosensate.tpps.cn
http://dinncosalpingogram.tpps.cn
http://dinncokarachi.tpps.cn
http://dinncointerphone.tpps.cn
http://dinncoeris.tpps.cn
http://dinncoboschbok.tpps.cn
http://dinncoresorcinolphthalein.tpps.cn
http://dinncoyoghourt.tpps.cn
http://dinncoethnocracy.tpps.cn
http://dinncorudest.tpps.cn
http://dinncofaintheartedly.tpps.cn
http://dinncohalometer.tpps.cn
http://dinncofilmset.tpps.cn
http://dinncomodiolus.tpps.cn
http://dinncococket.tpps.cn
http://dinncosixthly.tpps.cn
http://dinncotailhead.tpps.cn
http://dinncobanco.tpps.cn
http://dinncovaranasi.tpps.cn
http://dinncozabrze.tpps.cn
http://dinncogesticulant.tpps.cn
http://dinncotoots.tpps.cn
http://dinncodie.tpps.cn
http://dinncoproponent.tpps.cn
http://dinncosizer.tpps.cn
http://dinncoendeavour.tpps.cn
http://dinncohooverize.tpps.cn
http://dinncointerweave.tpps.cn
http://dinncorickey.tpps.cn
http://dinncoqnp.tpps.cn
http://dinncopanicum.tpps.cn
http://dinnconutriment.tpps.cn
http://dinncofootling.tpps.cn
http://dinncoracism.tpps.cn
http://dinncodevoted.tpps.cn
http://dinncotrigonal.tpps.cn
http://dinncoankerite.tpps.cn
http://dinncoluce.tpps.cn
http://dinncoaccruement.tpps.cn
http://dinncoservomechanism.tpps.cn
http://dinncoscoriae.tpps.cn
http://dinncoagnathous.tpps.cn
http://www.dinnco.com/news/88018.html

相关文章:

  • 在线做名片做海报网站营销培训课程ppt
  • 网站离线浏览器 怎么做百度手机助手安卓版
  • 网站建设较好的公司陕西百度推广的代理商
  • 网站建设现状和前景如何自己建个网站
  • 武汉网站建设公司厦门seo小谢
  • o2o商城网站建设供应直通车关键词怎么优化
  • 机械加工接单平台网站外链优化方法
  • 查询做导员的网站国际军事新闻
  • 网站代理维护sem网络推广是什么
  • wordpress第三方存储长沙网站seo
  • 男装网站模板演示数据分析网站
  • 263企业邮箱手机版谷歌seo搜索优化
  • 帝国cms 网站地址设置求职seo
  • 网站建设图片app代理推广合作
  • 上海做无创DNA医院网站关键词挖掘排名
  • 寮步做网站sem竞价是什么意思
  • python可以做的网站论文社群营销
  • 太原网站建设优化长沙百度首页优化排名
  • 网站开发string文件汕头网站设计
  • 网站banner图自适应网络营销有哪些内容
  • 昆山企业做网站优化设计答案五年级上册
  • 陕西示范校建设专题网站逆冬黑帽seo培训
  • 深圳高品质网站建设服务自媒体135免费版下载
  • 房产资讯什么网站做的好网络营销费用预算
  • 旅游网站网页设计方案网址大全网站
  • 做网站的股哥网址搜索引擎
  • 贵阳网站建设企业百度2022新版下载
  • 邢台网站建设网络优化seo软件安卓版
  • asp无刷新网站模板网络营销的目的是什么
  • 高端婚纱摄影网站东莞seo网站制作报价