Vue中组件之间数据通信
组件数据传递
组件数据传递的实现方式
- vuex
- prop和emit方式
- store
- eventBus
1.父传子
父组件向组件传递数据,通过子组件中prop属性接受父作用域中的属性
父组件
<part-component buttonKey="列斯"></part-component>
export default {
name: 'modulePart1',
components: { partComponent },
data () {
}
}
子组件
export default {
name: 'partComponent',
props: {
buttonKey: {
type: String
}
},
data () {
return {
}
}
}
注意
- 传递数组、布尔、对象、数字必须使用动态prop的方式,如:prop="number"
- 传递一个对象的所有property使用:prop="post",post为对象
- 子组件使用inheritAttrs:false,避免未在prop中注册的属性
子传父使用emit事件传递的方式
父组件
<part-component buttonKey="列斯" @fnToFather="fnToFather"></part-component>
fnToFather (s) {
this.info = s
}
子组件
<ta-button @click="fnToFather">{{buttonKey}}</ta-button>
fnToFather () {
this.$emit('fnToFather', '来自子组件的数据')
}
2.兄弟
- 通过子传父,父再传子的方式,这里不介绍
- 通过eventBus实现
- 声明Bus总线
//声明Bus.js
import Vue from 'Vue'
export default new Vue
2.发出事件
import Bus from 'Bus.js'
Bus.$emit("eventName","content")
3.监听事件
import Bus from 'Bus.js'
Bus.$on("eventName",data=>{
//数据处理
})
- 通过sessionstorage实现
- A组件
sessionStorage.setItem();
- B组件
sessionStorage.getItem()
3.爷孙
- 通过爷传父,父传子事件
- 通过eventBus总线实现
- sessionstorge实现
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 不到万不得已,千万不要去外包
· C# WebAPI 插件热插拔(持续更新中)
· 会议真的有必要吗?我们产品开发9年了,但从来没开过会
· 【译】我们最喜欢的2024年的 Visual Studio 新功能
· 如何打造一个高并发系统?