背景
Vue3.0集成Bus
方式一:全局引入
cnpm install --save mitt
import { createApp } from "vue";
import App from "./App.vue";
import router from "./router";
import store from "./store";
//这里引入
import mitt from "mitt";
const app = createApp(App);
app
.use(store)
.use(router)
.mount("#app");
//这里初始化
app.config.globalProperties.$bus = mitt();
- 页面中使用 ,由于是全局的,所以在使用页面中不需要再引入,直接使用。代码如下:
- 发起方:我这个例子是在选中方法中发起。
- 接收方:记住一定要写在mounted,这里一定要格外注意,千万不要写在method中,如果你用WebStorm是不会报错误的,这个bug非常不好排查,我是深受其害,费了很大劲才找到错误。
方式二:按需引入,即那个组件需要就在哪里引入,我个人比较推荐这种方式。
- 在src下新建package,命名为bus,新建bus.js
- bus.js中引入mitt,同时对外声明bus,在使用页面直接引入bus即可。
import mitt from "mitt";
const bus = mitt();
export default bus;
总结
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
- 找不到素材资源介绍文章里的示例图片?
- 对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
- 模板不会安装或需要功能定制以及二次开发?
- 请QQ联系我们
发表评论
还没有评论,快来抢沙发吧!