vue全局组件通信

🎉🎉全局组件通信

在这里插入图片描述

📌 $bus

main.js挂载:

new Vue({
    el:'#app',
    render: h => h(App),
    beforeCreate(){
        Vue.prototype.$bus = this      // 安装全局事件总线  $bus
    }
})

A—>B组件通信:例:B触发A组件中的事件
A:

  //监听getSome事件
  mounted() {
       this.$bus.$on('getSome',(data)=>{
            console.log('A组件接收到的数据',data);
       })
   },
    //解绑getSome事件
  beforeDestroy() {
       this.$bus.$off('getSome');
    },

B:

  this.$bus.$emit('getSome','我是B组件,向A组件发送点数据');

📌 $on

任意组件监听全局事件
A.vue

//beforeMount==>页面data数据已初始化完成,未挂载到页面上
beforeMount() {
	this.globalEventBind();
},

methods:{
 	//全局事件绑定-->upData
    globalEventBind() {
      //解绑事件
      this.$root.$off("upData");
      this.$root.$on("upData", (data) => {
  			console.log(data);
      });
    },
}

//任意位置触发A组件中绑定的 upData事件

 this.$root.$emit("upData", {
        name: 'wg',
        sex: 'man',
      });

📌 Vuex

目录结构
在这里插入图片描述

app.js
	const state = {
		userId: 'dfges4fdsaf0', //用户id
	}

	const mutations = {
		CHECK_SDID: (state, id) => {
			state.userId= id
		},
	}
	
	const actions = {}
	
	export default {
		namespaced: true,
		state,
		actions,
		mutations
	}

getters.js
const getters = {
	id: state => state.app.id;
	//若有多个模块,如
	id2: state.app2.id
	
}
export default getters
index.js
import Vue from 'vue'
import Vuex from 'vuex'
import getters from './getters'
import app from './modules/app'
Vue.use(Vuex)

const store = new Vuex.Store({
	modules: {
		app
	},
	getters
})

export default store
miain.js 挂载
import store from './store';
new Vue({
    router,
    store,
    render: h => h(App)
}).$mount('#app')
vue文件使用
	import store from "../../../store";
	import { mapGetters } from 'vuex';
	computed: {
		//实时响应vuex数据
		...mapGetters([
			'id',
		]),
	}
	//或
	 computed: {
	    // 对属性重命名,使用 getId
	    ...mapGetters("app", {getId: "id"});
	}

	//使用vuex里数据
	//this.id即可
	
	//或
	let myid = store.getters["app/id"]

	
	//调用vuex方法
	store.commit("app/CHECK_SDID", '6799');
	

在这里插入图片描述

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@才华有限公司

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值