前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue使用bus进行组件间、父子路由间通信

Vue使用bus进行组件间、父子路由间通信

作者头像
Java架构师必看
发布2021-09-14 14:17:44
5010
发布2021-09-14 14:17:44
举报
文章被收录于专栏:Java架构师必看

Vue使用bus进行组件间、父子路由间通信

强烈推介IDEA2020.2破解激活,IntelliJ IDEA 注册码,2020.2 IDEA 激活码

1.前言

在项目中遇到需要在父路由中调用子路由中的方法,这样的问题实际也是组件间的通信,在子路由中可以直接通过this.$parent.xxx来调用父页面中的方法,但反过来就有点头疼了,经过一番查阅后通过bus成功解决问题,这里仅记录如何解决应用问题,不追究bus更多的原理。

2.抽取封装bus

项目src下新建utils目录,新建bus.js:

代码语言:javascript
复制
import Vue from 'vue'
const bus = new Vue()
export default bus 
3.子路由中监听

首先引入bus.js:

代码语言:javascript
复制
import bus from "@/utils/bus";

页面渲染完成即开始监听需要在父页面中使用的方法:

代码语言:javascript
复制
methods:{
   
        test(){
   
          console.log('123');
        },
	},
mounted() {
   
        bus.$on('test',this.test);
    }
4.父页面中触发方法

引入bus.js:

代码语言:javascript
复制
import bus from "@/utils/bus";

触发:

代码语言:javascript
复制
methods:{
   
		createGroup(){
   
          bus.$emit('test')
        },
	}

这样在父页面中给一个按钮绑定createGroup点击事件后,点击按钮后便可以调用子路由中的test方法。

5.注意

由于子路由页面中是在mounted中监听的方法,可能出现多次监听的情况,进而引起监听的方法多次触发的问题。只需要在监听前先取消就行:

代码语言:javascript
复制
mounted() {
   
		bus.$off('test');
        bus.$on('test',this.test);
    }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.前言
  • 2.抽取封装bus
  • 3.子路由中监听
  • 4.父页面中触发方法
  • 5.注意
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档