Vue.js 组件如何通信以及有哪些方式?

🌙
手机阅读
本文目录结构

问题

Vue组件如何通信以及有哪些方式?

单向数据流

答案

  • 父子间通信 父->子通过props、子-> 父$on、$emit
  • 获取父子组件实例的方式$parent、$children
  • 在父组件中提供数据子组件进行消费 Provide、inject
  • Ref获取实例的方式调用组件的属性或者方法
  • Event Bus 实现跨组件通信
  • Vuex 状态管理实现通信

1. ⽗⼦通信

⽗组件通过 props 传递数据给⼦组件,⼦组件通过 emit 发送事件传递数据给⽗组件, 这两种⽅式是最常⽤的⽗⼦通信实现办法。

这种⽗⼦通信⽅式也就是典型的单向数据流,⽗组件通过 props 传递数据,⼦组件不能 直接修改 props ,⽽是必须通过发送事件的⽅式告知⽗组件修改数据。

另外这两种⽅式还可以使⽤语法糖 v-model 来直接实现,因为 v-model 默认会解析成 名为 value 的 prop 和名为 input 的事件。这种语法糖的⽅式是典型的双向绑定, 常⽤于 UI 控件上,但是究其根本,还是通过事件的⽅法让⽗组件修改数据。

当然我们还可以通过访问 $parent 或者 $children 对象来访问组件实例中的⽅法和数 据。

另外如果你使⽤ Vue 2.3 及以上版本的话还可以使⽤ $listeners 和 .sync 这两个属 性。

$listeners 属性会将⽗组件中的 (不含 .native 修饰器的) v-on 事件监听器传递给 ⼦组件,⼦组件可以通过访问 $listeners 来⾃定义监听器。

.sync 属性是个语法糖,可以很简单的实现⼦组件与⽗组件通信

<!--⽗组件中-->
<input :value.sync="value" />
<!--以上写法等同于-->
<input :value="value" @update:value="v => value = v"></comp>
<!--⼦组件中-->
<script>
this.$emit('update:value', 1)
</script>

2. 兄弟组件通信

对于这种情况可以通过查找⽗组件中的⼦组件实现,也就是 this.$parent.$children ,在 $children 中可以通过组件 name 查询 到需要的组件实例,然后进⾏通信。

3. 跨多层次组件通信

对于这种情况可以使⽤ Vue 2.2 新增的 API provide / inject ,虽然⽂ 档中不推荐直接使⽤在业务中,但是如果⽤得好的话还是很有⽤的。

假设有⽗组件 A ,然后有⼀个跨多层级的⼦组件 B

// ⽗组件 A
export default {
    provide: {
        data: 1
    }
}
// ⼦组件 B
export default {
    inject: ['data'],
    mounted() {
        // ⽆论跨⼏层都能获得⽗组件的 data 属性
        console.log(this.data) // => 1
    }
}

终极办法解决⼀切通信问题

只要你不怕麻烦,可以使⽤ Vuex 或者 Event Bus 解决上述所有的通信情 况。

扩展:

以前博客里也有总结这个问题

https://www.axihe.com/anbang/blog/vue/vue-component-communication.html

更多面试题

如果你想了解更多的前端面试题,可以查看本站的WEB前端面试题 ,这里基本包涵了市场上的所有前端方面的面试题,也有一些大公司的面试图,可以让你面试更加顺利。

面试题
HTML CSS JavaScript
jQuery Vue.js React
算法 HTTP Babel
BootStrap Electron Gulp
Node.js 前端经验相关 前端综合
Webpack 微信小程序 -

这些题库还在更新中,如果你有不错的面试题库欢迎分享给我,我整理后放上来;人人为我,我为人人,互帮互助,共同提高,祝大家都拿到心仪的Offer!

AXIHE / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili

关注我: Github / 知乎

于2021年离开前端领域,目前重心放在研究区块链上面了

我叫朱安邦,阿西河的站长

目前在杭州从事区块链周边的开发工作,机械专业,以前从事平面设计工作。

2014年底脱产在老家自学6个月的前端技术,自学期间几乎从未出过家门,最终找到了满意的前端工作。更多>

于2021年离开前端领域,目前从事区块链方面工作了