vue2.0非父子组件间怎么进行通讯?

互联网 20-11-5
下面Vue.js教程栏目给大家介绍一下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>

此时就已经可以达到我们想要的效果啦。

2020年前端vue面试题大汇总(附答案)

vue教程推荐:2020最新的5个vue.js视频教程精选

更多编程相关知识,请访问:编程教学!!

以上就是vue2.0非父子组件间怎么进行通讯?的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 组件通讯
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:vue+axios+php如何实现上传文件功能?

相关资讯