JavaScript实现事件总线(Lab小技巧-005)

栏目: JavaScript · 发布时间: 5年前

内容简介:近日沉迷搬砖(偷懒),都没什么时间更新文章了,砖搬的差不多了赶紧回来写点小玩意~依旧是背景介绍,我们在网购的时候都填过地址吧,一般点击编辑地址的时候都会跳到新的页面,那么问题来了,我们编辑好提交之后,怎么把数据给回上一个页面呢?如果我们遇到上面的情景会怎么解决呢?方案倒不少,storage、状态管理甚至暂存到全局。今天我想介绍的方案是EventBus,也就是我们常说的事件总线,也可以认为是发布/订阅模式,废话不多说,直接进入正题。

近日沉迷搬砖(偷懒),都没什么时间更新文章了,砖搬的差不多了赶紧回来写点小玩意~

依旧是背景介绍,我们在网购的时候都填过地址吧,一般点击编辑地址的时候都会跳到新的页面,那么问题来了,我们编辑好提交之后,怎么把数据给回上一个页面呢?

如果我们遇到上面的情景会怎么解决呢?方案倒不少,storage、状态管理甚至暂存到全局。今天我想介绍的方案是EventBus,也就是我们常说的事件总线,也可以认为是发布/订阅模式,废话不多说,直接进入正题。

用了EventBus之后有何不同?

引入事件总线之后,在下单页跳转至地址编辑页之前,我们可以订阅一个事件例如:订阅一个key为"address"的事件,并规定事件触发后该执行的函数,比如将获取到的信息展示出来。

在地址编辑页完成编辑后,我们会发布一个key为"address"的事件,并传递一些参数(例如此处应传递地址信息)。事件发布后,会触发订阅通道中key为"address"的事件回调。这样就完成了我们需要的数据传递并展示。

如何实现一个简易的EventBus

首先我们看张示意图,对EventBus有个更直观的了解。

JavaScript实现事件总线(Lab小技巧-005)

不难发现,我们完成一个简易的EventBus其实只需这么3个方法 -- on/emit/off

  • 事件订阅 -- on
JavaScript实现事件总线(Lab小技巧-005)

首先构造一个EventBus函数,然后给它赋予on方法。该方法可传入三个值,key/cb/isKeep分别代表订阅的键值、事件回调以及是否持久化订阅。

实际情况中,我们很多时候的事件订阅都是一次性动作,所以我们的订阅行为默认是一次性的并且isKeep也不作为必备参数。

但是key则不一样,如果没有key的传入这个方法是完全没有意义的,所以我们将key值设为必备的参数。获得key后,首先会在events对象中查看是否已存在,如果没有则为这个key新增一个属性并赋予空组数,最后把事件回调以及是否持久化作为对象传入数组中。

  • 取消订阅 -- off
JavaScript实现事件总线(Lab小技巧-005)

如果我们不想再订阅某个事件,我们就需要一个取消订阅的方法,因为我们一个订阅事件是可以触发多个回调的,所以我们取消订阅有两种模式,一种是取消某个回调,一种是取消整个事件订阅。

这里我们可传入两个值,一个是key一个是cb,如果没有传入cb则代表取消整个事件订阅。

取消整个事件订阅好办,直接将this.events内的对应key的属性delete即可。如果需要删除指定key的某个回调则需要把目标回调函数引用也传入off方法中,找到相应对象删除。

看到这里,大家可能会想,如果我传的是个匿名函数不是就没法取消了?恭喜你,答对了。所以我们在设置回调函数的时候尽量不要使用匿名函数。(如果我们确实需要取消应该咋办?在拓展中我们会展开讨论一下)

  • 事件发布 -- emit
JavaScript实现事件总线(Lab小技巧-005)

最后是事件发布,发布的重点在于参数的传递以及一次性订阅的取消。我们通过函数内置的arguments属性将需要传入触发事件的参数取出来,然后通过apply方法传入函数中。

对于不需要keep的订阅,我们则需要在handler触发后调用自身的off方法将其删除即可。

拓展

  • 发布/订阅模式和观察者模式,傻傻分不清

乍一看,两种模式十分相似,都有所谓的订阅与发布动作,但有一个很大的不同:调度方式。

发布/订阅模式有一个调度中心的概念,也就是我们这里所说的事件总线,所有的事件调度都是在这里面进行的;而观察者模式则是由被观察对象主动调度,没有事件总线的概念。相比之下发布/订阅模式更加解耦,发布、订阅者完全没有依赖。

  • 取消匿名函数回调

① 如果是一次性订阅则可以直接根据引用进行订阅取消。

② 如果不是一次性订阅,但是我们又想取消则可以参照setTimeout的做法,我们在订阅事件的时候随机生成一个token,并加入订阅对象中,最后作为on的返回值,暴露出来。取消订阅也是意义,就和我们clearTimeout一样,将token传入off方法中,达到取消的目的。

JavaScript实现事件总线(Lab小技巧-005)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法心得:高效算法的奥秘(原书第2版)

算法心得:高效算法的奥秘(原书第2版)

(美)Henry S. Warren, Jr. / 爱飞翔 / 机械工业出版社 / 2014-3 / 89.00

【编辑推荐】 由在IBM工作50余年的资深计算机专家撰写,Amazon全五星评价,算法领域最有影响力的著作之一 Google公司首席架构师、Jolt大奖得主Hoshua Bloch和Emacs合作创始人、C语言畅销书作者Guy Steele倾情推荐 算法的艺术和数学的智慧在本书中得到了完美体现,书中总结了大量高效、优雅和奇妙的算法,并从数学角度剖析了其背后的原理 【读者评价......一起来看看 《算法心得:高效算法的奥秘(原书第2版)》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

在线进制转换器
在线进制转换器

各进制数互转换器

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器