这篇文章将为大家详细讲解有关vue2.0非父子组件间如何进行通讯,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
在vue中,父组件向之组件通讯使用的是props,子组件向父组件通讯使用的是$emit+事件,那非父子间的通讯呢,在官方文档上只有寥寥数笔,
概念很模糊,这个空的vue实例应该放在哪里呢,光放文档并没有明确的描述,经过查证一些其他的资料,发现其实这个非父子间的通讯是这么用的:
首先,这个空的实例需要放到根组件下,所有的子组件都能调用,即放在main.js下面,如图所示:
import Vue from 'vue' import App from './App' import router from './router' Vue.config.productionTip = false; /* eslint-disable no-new */ new Vue({ el: '#app', router, data:{ Hub:new Vue() }, template: '<App/>', components: { App } });
我的两个组件分别叫做child1.vue,child2.vue,我现在想点击child1.vue里面的按钮来改变child2.vue里面的数值,这个时候我们需要借助一个$root的工具来实现:
child1.vue:
<template lang="pug"> p this is child span(@click="correspond") 点击进行非组件之间的通信 </template> <script> export default{ methods: { correspond(){ this.$root.Hub.$emit("change","改变") } } } </script>
child2.vue:
<template lang="pug"> p this is child2 span {{message}} </template> <script> export default{ data(){ return { message: "初始值" } }, created(){ this.$root.Hub.$on("change", () => { this.message = "改变" }) } } </script>
此时就已经可以达到我们想要的效果啦。
关于vue2.0非父子组件间如何进行通讯就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。