Vue组件间通信方式超详细(父传子、父传后代、子传父、后代传父、兄弟组件传值)
创始人
2024-05-27 11:26:51

一、父传子、父传后代

方式一:子通过props来接收

image.png
父组件:父组件引入子组件时,通过子组件传值。

备注:这种方式父传值很方便,但是传递给后代组件不推荐(父->子->孙),且这种方式父组件不能直接修改父组件传过来的数据。



子组件:子组件通过props即props:{ parentValue:{ type:String, default:"" } }来接收父组件传过来的值



方式二:通过this.$parent.xxx子组件直接使用父组件的值

备注:这种方式,子组件可以直接修改父组件的数据。

image.png
父组件:正常引入子组件


子组件:通过this.$parent.parentValue获取父组件的数据。


方式三:依赖注入provide/inject

备注:这种方式父组件可以直接向某个后代组件传值,不用再一级一级的传递。

缺点:很难去找这个值是从哪个组件传递过来的。

image.png
父组件:通过provide定义需要传递给后代的数据。


子组件:


孙子组件:通过inject注入爷爷辈组件传递过来的值。



效果图:

image.png

二、子传父、后代传父

方式一:this.$emit(“function”,param)

子组件通过$emit传递一个函数和参数,父组件通过传递过来的函数接收参数即传过来的值。

父子组件一般会触发交互行为(子组件传递过来的值放在生命周期函数里是传不过来的),所以可以通过父子的交互行为获取到子组件传递过来的数据。

image.png
父组件:通过子组件自定义的函数进行绑定接收传递过来的数据。


子组件:通过this.emit("function",param)子组件通过emit("function",param) 子组件通过emit("function",param)子组件通过emit传递一个函数和参数,父组件通过传递过来的函数接收参数即传过来的值。


效果图:

image.png

方式二:this.$child.xxx直接获取子组件数据,且可直接修改子组件的数据。

父组件:this.$children[0].childValue获取子组件数据,只有一个子组件故下标为0.


子组件:


方式三:通过ref/refs获取子组件dom从而直接获取子组件数据。可直接修改子组件数据。

父组件:


子组件与上述相同。

三、兄弟组件传值

方式一:通过中转eventBus.js工具类

新建一个中转eventBus.js工具类,传值的兄弟组件自定义一个函数通过

eventBus.$emit('function',参数);

给接收值的兄弟组件传一个约定好的function名称及参数(即传递的值);接收值的兄弟组件通过

eventBus.$on('function',val=>{console.log("传递过来的值",val)
})

来接收传递过来的值。

image.png
eventBus.js:

import Vue from 'vue'
export default new Vue();

传值的兄弟组件:


接收值的兄弟组件:


效果图:
在这里插入图片描述

相关内容

热门资讯

正扬科技创业板IPO获受理 拟... 汽车电子零部件企业正扬科技闯关IPO。5月7日深交所网站显示,广东正扬传感科技股份有限公司(简称“正...
刘海星会见孟加拉国外长卡利勒 5月7日,中共中央对外联络部部长刘海星在北京会见孟加拉国外长卡利勒。刘海星祝贺孟新政府施政实现良好开...
挪威央行加息以应对通胀压力 挪威央行7日宣布,将基准利率上调0.25个百分点至4.25%,以应对持续高企的通胀压力。挪威央行表示...
U17女足亚洲杯中国队6比0胜... 北京时间5月7日晚,2026亚足联U17女足亚洲杯小组赛A组的争夺全部结束。在苏州太湖足球运动中心1...
菲海岸警卫队1架岛人型机蓄意抵... 中国海警局新闻发言人姜略表示,5月6日,中方向阳红33号船位中国鲎藤礁附近海域开展正常生态环境调查。...