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

1.前言

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

2.抽取封装bus

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

import Vue from 'vue'
const bus = new Vue()
export default bus 
3.子路由中监听

首先引入bus.js:

import bus from "@/utils/bus";

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

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

引入bus.js:

import bus from "@/utils/bus";

触发:

methods:{
		createGroup(){
          bus.$emit('test')
        },
	}

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

5.注意

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

mounted() {
		bus.$off('test');
        bus.$on('test',this.test);
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值