1.0.6 • Published 6 years ago
enhance-eventbus v1.0.6
enhance-eventbus
介绍
eventBus 是一个典型的发布订阅模式的实践,而这个包的基础功能就是发布订阅。
eventBus 在 node.js 中本就自带,所以为什么需要写这个包呢?
其实从包名 enhance-eventbus 中也可以看出来,这是一个增强 (其实是不会起名字) 的 eventBus。
它比普通的 eventBus 多了可以在浏览器跨 tab (有同源限制)。
它的 api 跟普通的 eventBus 是一样的使用方式的,极其简单, 相信使用过 vue 里面 eventBus( new 一个 vue 实例作为eventBus)的小伙伴们, 都知道怎么使用~
example

StorageEventBus
这里实现原理是利用了 storage 去监听的,所以这里在相同一个 window tab 页面是无法触发事件的,需要开启别的 tab 才能通信。
// yarn add enhance-eventbus or npm i -S enhance-eventbus
const eventBus = new tabeventbus.StorageEventBus({
isDev: () => true
})
eventBus.on('someEvent', (data) => {
console.log(data)
})
eventBus.emit('someEvent', {msg: 'hello world'})use in your vue project
// in the main.js
import enhanceEventbus from "enhance-eventbus"
import Vue from "vue"
Vue.use(enhanceEventbus, {
type: "storage",
globalKey: "$eventBus" // 这里配置的是 vue.prototype 挂载的属性名叫什么
})
// and then you can use it by the gloalKey that your define
new Vue({
mounted() {
this.$eventBus.on('someEvent', (data) => {
// ...to do sth
})
this.$eventBus.emit('someEvent', data)
}
})感谢以下项目(排名不分先后)
- typescript-library-starter 库的依赖有点老旧,升级下就能用了
- typescript