• 技术文章 >web前端 >Vue.js

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

    青灯夜游青灯夜游2020-11-05 18:02:11转载427
    下面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非父子组件间怎么进行通讯?的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:博客园,如有侵犯,请联系admin@php.cn删除
    专题推荐:vue2.0 组件通讯
    上一篇:详解vue验证器(vue-validator)的使用 下一篇:vue+axios+php如何实现上传文件功能?
    大前端线上培训班

    相关文章推荐

    • 分析一下Vue.use的源码• vue如何实现局部刷新?(代码示例)• 深入了解vue中的计算属性• 浅谈vue中axios的封装• 详解Vue中动态添加类名的方法

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网