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!