Vue.js 父子组件通信的十种方式(转载)

在这里插入图片描述

1、prop

这个在我们日常开发当中用到的非常多。简单来说,我们可以通过 Prop 向子组件传递数据。用一个形象的比喻来说,父子组件之间的数据传递相当于自上而下的下水管子,只能从上往下流,不能逆流。这也正是 Vue 的设计理念之单向数据流。而 Prop 正是管道与管道之间的一个衔接口,这样水(数据)才能往下流。

在这里插入图片描述

浏览器输出

在这里插入图片描述

2、$emit

官方说法是触发当前实例上的事件。附加参数都会传给监听器回调。

在这里插入图片描述

大致逻辑如下:当我在页面上点击按钮时,触发了组件 MyButton 上的监听事件 greet,并且把参数传给了回调函数 sayHi 。说白了,当我们从子组件 Emit(派发) 一个事件之前,其内部都提前在事件队列中 On(监听)了这个事件及其监听回调。其实相当于下面这种写法:

在这里插入图片描述

3、.sync 修饰符

[email protected] 的时候曾作为双向绑定功能存在,即子组件可以修改父组件中的值。因为它违反了单向数据流的设计理念,所以在 [email protected] 的时候被干掉了。但是在 [email protected]+ 以上版本又重新引入了这个 .sync 修饰符。但是这次它只是作为一个编译时的语法糖存在。它会被扩展为一个自动更新父组件属性的 v-on 监听器。说白了就是让我们手动进行更新父组件中的值了,从而使数据改动来源更加的明显。下面引入自官方的一段话:

在有些情况下,我们可能需要对一个 prop 进行“双向绑定”。不幸的是,真正的双向绑定会带来维护上的问题,因为子组件可以修改父组件,且在父组件和子组件都没有明显的改动来源。

既然作为一个语法糖,肯定是某种写法的简写形式,哪种写法呢,看代码
在这里插入图片描述
于是我们可以用 .sync 语法糖简写成如下形式:
在这里插入图片描述
那么如何做到“双向绑定” 呢?
假如我们想实现这样一个效果:改变子组件文本框中的值同时改变父组件中的值。怎么做?先看段代码:
在这里插入图片描述
下面划重点,代码里有这一句话:
在这里插入图片描述
官方语法是:update:myPropName 其中 myPropName 表示要更新的 prop 值。当然如果你不用 .sync 语法糖使用上面的 .$emit 也能达到同样的效果。仅此而已!
4、属性attrs 和 $listeners
在这里插入图片描述
在这里插入图片描述
从 Html 中可以看到,这里有俩属性和俩方法,区别是属性一个是 prop 声明,事件一个是 .native 修饰器。
在这里插入图片描述
在这里插入图片描述
一个插曲!

当我们在组件上赋予了一个非Prop 声明时,编译之后的代码会把这些个属性都当成原始属性对待,添加到 html 原生标签上,看上面的代码编译之后的样子:
在这里插入图片描述
这样会很难看,同时也爆了某些东西。如何去掉?这正是 inheritAttrs 属性的用武之地!给组件加上这个属性就行了,一般是配合 $attrs 使用。看代码:
在这里插入图片描述
再次编译:
在这里插入图片描述
5、provide / inject
官方对 provide / inject 的描述:
在这里插入图片描述
一句话总结就是:小时候你老爸什么东西都先帮你存着等你长大该娶媳妇儿了你要房子给你买要车给你买只要他有的尽量都会满足你*(看到这句笑出了声)*。下面是这句话的代码解释:
在这里插入图片描述
6、其他方式通信
除了以上五种方式外,其实还有:

  • EventBus
    思路就是声明一个全局Vue实例变量 EventBus , 把所有的通信数据,事件监听都存储到这个变量上。这样就达到在组件间数据共享了,有点类似于 Vuex。但这种方式只适用于极小的项目,复杂项目还是推荐 Vuex。下面是实现 EventBus 的简单代码:
    在这里插入图片描述

  • Vuex
    官方推荐的,Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。

  • $parent
    父实例,如果当前实例有的话。通过访问父实例也能进行数据之间的交互,但极小情况下会直接修改父组件中的数据。

  • $root
    当前组件树的根 Vue 实例。如果当前实例没有父实例,此实例将会是其自己。通过访问根组件也能进行数据之间的交互,但极小情况下会直接修改父组件中的数据。

  • broadcast / dispatch
    他俩是 [email protected] 中的方法,分别是事件广播 和 事件派发。虽然 [email protected] 里面删掉了,但可以模拟这两个方法。可以借鉴 Element 实现。有时候还是非常有用的,比如我们在开发树形组件的时候等等。

        </div>
					<link href="https://csdnimg.cn/release/phoenix/mdeditor/markdown_views-258a4616f7.css" rel="stylesheet">
                  </div>

猜你喜欢

转载自blog.csdn.net/qq_31001889/article/details/89595117
今日推荐