首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何用Vue路由器将道具传递给子组件?

如何用Vue路由器将道具传递给子组件?
EN

Stack Overflow用户
提问于 2020-04-14 09:40:28
回答 1查看 617关注 0票数 0

我有一个带有导航和布局的Vue组件,它使用总线与子组件通信。总线作为支柱传递给使用$emit的子组件。

代码语言:javascript
复制
export default class Dashboard extends Vue {

  protected bus: Vue = new Vue();

  mounted() {
    if (this.bus != null) {
      this.bus.$on("save", () => {
        //
      });
    }
  }
}

@Component({ props: ["bus"] })
export default class Child extends Vue {
   protected bus!: Vue;

   save() {
      this.bus.$emit("save");
   }  
}

这在标准情况下很好。

在Vue路由器的情况下,如何将来自父节点的总线组件注入子节点?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-14 13:30:28

您应该在一个单独的文件中创建一个总线实例,您可以将其导入到任何其他需要使用它的文件中,实例将在导入的所有地方持久存在。

您可以使用data()对象,而不是作为道具传递,因为它将充当全局存储,但这正是维克斯的目的。

代码语言:javascript
复制
// BusDepot.js

import Vue from 'vue'

export const DashboardBus = new Vue({
  data: {
   mySharedValue: 'Its global!'
  }
})
代码语言:javascript
复制
import { DashboardBus } from 'BusDepot'

export default class Dashboard extends Vue {

  created () {

    DashboardBus.$on('save', () => {

      console.log(DashboardBus.mySharedValue)

    });

  }

}
代码语言:javascript
复制
import { DashboardBus } from 'BusDepot'

export default class Child extends Vue {

   save() {
      DashboardBus.$emit('save');
   }  
}

如果使用维克斯作为中央数据存储来解决道具传递的问题,则可以使用主Vue实例作为事件总线:

代码语言:javascript
复制
import { DashboardBus } from 'BusDepot'

export default class Dashboard extends Vue {

  created () {
    const vm = this

    vm.$root.$on('dashbaord.save', () => {

      console.log(vm.$store.state.mySharedValue)

    });

  }

}
代码语言:javascript
复制
import { DashboardBus } from 'BusDepot'

export default class Child extends Vue {

   save() {
      this.$root.$emit('dashbaord.save');
   }  
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61204710

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档