vue组件间通信

2021-10-29  本文已影响0人  YiYaYiYaHei

本文主要介绍父->子、子->父、兄弟组件间、跨级组件间的传值方式。

一、props【父->子】

在父组件页面使用v-bind: 或 :将数据传递给子组件,子组件通过props获取父组件传递过来的值。

图1-1 父组件
图1-2 子组件
图1-3 效果

二、$attrs【父->子】

多级组件嵌套需要传递数据时,通常使用的方法是通过vuex。但如果仅仅是传递数据,而不做中间处理,使用 vuex 处理,未免有点大材小用。为此Vue2.4 版本提供了另一种方法----$attrs

1. $attrs:
图2-1

示例:
我们向子组件son传递5个属性,再由子组件son向孙子组件grandson传递4个属性(这4个组件不做任何处理,只是传递),son组件向grandson组件传递的那4个属性就可以使用v-bind=$attrs

图2-2
图2-3
2. interitAttrs:

通常和$attrs配合使用。

图2-4

简单来说,使用interitAttrs: false子组件的$attrs不会被当做是html属性渲染到根元素上,防止修改html同名属性。

图2-5
图2-6

三、$emit【子->父】

在子组件页面使用this.$emit('自定义事件名', 数据);将数据传递给父组件,父组件通过@自定义事件名="事件处理方法名" 或者v-on:自定义事件名="事件处理方法名"获取子组件传递过来的值。

图3-1 子组件
图3-2 父组件
图3-3 效果

四、$listeners【子->父】

1. 简介
图4-1
2. 使用
图4-2
图4-3

若公共组件被很多组件调用且抛出的自定义事件都不同,此时就可以使用$listeners;根据父组件调用的事件去决定抛出哪个自定义事件。

图4-4
图4-5

五、EventBus【父->子、子->父、兄弟组件间、跨级组件间】

1.简介

EventBus 又称为事件总线。在Vue中可以使用 EventBus 来作为沟通桥梁的概念,就像是所有组件共用相同的事件中心,可以向该中心注册发送事件或接收事件,所以组件都可以上下平行地通知其他组件,但也就是太方便所以若使用不慎,就会造成难以维护的灾难,因此才需要更完善的Vuex作为状态管理中心,将通知的概念上升到共享状态层次。更多EventBus

2. 使用

六、vuex【兄弟组件间、跨级组件间】

vuex官网

1. vuex原理
图6-1

Vuex实现了一个单向数据流,在全局拥有一个State存放数据,当组件要更改State中的数据时,必须通过Mutation进行,Mutation同时提供了订阅者模式供外部插件调用获取State数据的更新。而当所有异步操作(常见于调用后端接口异步获取更新数据)或批量的同步操作需要走Action,但Action也是无法直接修改State的,还是需要通过Mutation来修改State的数据。最后,根据State的变化,渲染到视图上。

2. 模块介绍
3. 解决vuex刷新状态消失问题
import Vuex from 'vuex';
// 解决刷新浏览器,数据消失问题
import createPersistedState from 'vuex-persistedstate';
Vue.use(Vuex);

export default new Vuex.Store({
  plugins: [createPersistedState()]
});

七、provide/inject【父 -> 子、跨级组件间】

provide / inject 官网介绍

1. 简介

vue2.2.0 新增API,这对选项需要一起使用,以允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在其上下游关系成立的时间里始终生效。如果你熟悉 React,这与 React 的上下文特性很相似。
provide / inject API 主要解决了跨级组件间的通信问题。官网提供了很详细的介绍,这里直接上图

图7-1
2. 使用

八、$parent、$children、$refs

1. 简介
2. 使用

由图8-1可知,this.$children获取到的是一个vue实列数组

图8-1 $children

由图8-2可知,this.$parent获取到的是直接父实例

图8-2 $parent

由图8-3可知,this.$refs返回的是一个使用ref注册过的对象

图8-3 $refs

九、sessionStorage、localStorage【父-> 子、子->父、兄弟组件间、跨级组件间】

sessionStorage、localStorage也能实现通信,但是需要监听storage的变化,如何监听storage的变化,之前有写过这篇文章vue 监听localStorage、sessionStorage变化,这里就不赘述了。

总结

1. 父 -> 子 间的通信
2. 子 -> 父 间的通信
3. 兄弟组件间的通信
4. 跨级组件间的通信
参考文章

vue组件间通信的六种方式

上一篇 下一篇

猜你喜欢

热点阅读