当前位置: 首页 > news >正文

Vue中的组件通信方式及应用场景

在Vue中,组件通信有以下几种方式:

  1. Props / $emit:父组件通过给子组件传递props属性,子组件通过$emit事件将数据传递给父组件。适用于父组件向子组件传递数据。

  2. 自定义事件:父组件通过$on监听子组件触发的事件,子组件通过$emit触发事件。适用于子组件向父组件传递数据或触发某些操作。

  3. $refs:父组件通过ref属性获取子组件的实例,从而调用子组件的方法或获取子组件的数据。

  4. $parent / $children:通过$parent属性获取父组件实例,通过$children属性获取子组件实例。可以直接访问父组件或子组件的数据和方法。

  5. Event Bus:通过创建一个全局的Vue实例,并使用$on、$emit等方法进行事件的监听和触发。不限制组件之间的层级关系,适用于任意组件之间的通信。

  6. Vuex:Vue的状态管理库,用于管理多个组件共享的状态数据。通过定义store、state、mutations等概念,实现组件之间的数据共享与通信。

适用场景:

  • Props / $emit:父子组件之间的数据传递。
  • 自定义事件:兄弟组件之间的数据传递或触发操作。
  • $refs:父组件获取子组件的数据或调用子组件的方法。
  • $parent / $children:父子组件之间的数据传递或方法调用。
  • Event Bus:任意组件之间的通信。
  • Vuex:大型应用中,多个组件需要共享数据的情况。

在Vue中,组件通信可以通过props、$emit、$on和$emit等方式来实现。

  1. 父组件向子组件传递数据:使用props 父组件可以通过props属性将数据传递给子组件。子组件可以在props中定义接收的属性,然后通过子组件的模板中使用这些属性。
// 父组件
<template><child-component :message="parentMsg"></child-component>
</template><script>
export default {data() {return {parentMsg: 'Hello from parent'}}
}
</script>// 子组件
<template><div>{{ message }}</div>
</template><script>
export default {props: ['message']
}
</script>

  1. 子组件向父组件传递数据:使用$emit 子组件可以使用$emit方法触发一个自定义事件,并传递数据给父组件。父组件可以在模板中监听这个自定义事件,并处理传递的数据。
// 子组件
<template><button @click="sendMessage">Send Message</button>
</template><script>
export default {methods: {sendMessage() {this.$emit('message', 'Hello from child')}}
}
</script>// 父组件
<template><child-component @message="handleMessage"></child-component>
</template><script>
export default {methods: {handleMessage(msg) {console.log(msg) // 输出:Hello from child}}
}
</script>

  1. 兄弟组件之间传递数据:使用事件总线 可以创建一个Vue实例作为事件总线,兄弟组件通过事件总线来通信。
// EventBus.js
import Vue from 'vue'
export default new Vue()// 组件A
<template><div><button @click="sendMessage">Send Message</button></div>
</template><script>
import EventBus from './EventBus'export default {methods: {sendMessage() {EventBus.$emit('message', 'Hello from component A')}}
}
</script>// 组件B
<template><div><div>{{ message }}</div></div>
</template><script>
import EventBus from './EventBus'export default {data() {return {message: ''}},created() {EventBus.$on('message', (msg) => {this.message = msg})}
}
</script>

这里仅展示了Vue中几种常用的组件通信方式和应用场景的代码示例,实际应用中还可以根据具体需求选择合适的通信方式。

相关文章:

  • 2024年道路运输企业主要负责人证考试题库及道路运输企业主要负责人试题解析
  • 各种基础环境搭建
  • Danil Pristupov Fork(强大而易用的Git客户端) for Mac/Windows
  • Keil5,ARM编译器 软件优化注意事项
  • 如何利用firewalld抵御DDOS攻击
  • pyqt6 + pycharm 搭建+使用入门
  • 两个bash函数创建一个数据库
  • C++笔记之cout高亮输出以及纯C++实现一个彩色时钟
  • Python+Django+MySQL的学生信息管理系统【附源码,运行简单】
  • 用Redis实现全局唯一ID
  • Python 使用input函数从键盘输入数据
  • LeetCode 每日一题 Day 36 ||模拟/字典序(哈希策略)
  • 扩散模型: Diffusion Model概念讲解
  • ubuntu 22 virt-manger(kvm)安装winxp; ubuntu22体验 firebird3.0
  • 云卷云舒:【实战篇】Sql Server迁移
  • php的引用
  • 《微软的软件测试之道》成书始末、出版宣告、补充致谢名单及相关信息
  • 【挥舞JS】JS实现继承,封装一个extends方法
  • 2017-08-04 前端日报
  • Consul Config 使用Git做版本控制的实现
  • flask接收请求并推入栈
  • HTTP传输编码增加了传输量,只为解决这一个问题 | 实用 HTTP
  • JS学习笔记——闭包
  • React Transition Group -- Transition 组件
  • React-flux杂记
  • SSH 免密登录
  • vue脚手架vue-cli
  • 从零开始的无人驾驶 1
  • 提醒我喝水chrome插件开发指南
  • ​​​​​​​​​​​​​​汽车网络信息安全分析方法论
  • ​【已解决】npm install​卡主不动的情况
  • ​Base64转换成图片,android studio build乱码,找不到okio.ByteString接腾讯人脸识别
  • ​如何使用ArcGIS Pro制作渐变河流效果
  • "无招胜有招"nbsp;史上最全的互…
  • # Python csv、xlsx、json、二进制(MP3) 文件读写基本使用
  • #NOIP 2014#day.2 T1 无限网络发射器选址
  • #设计模式#4.6 Flyweight(享元) 对象结构型模式
  • #数学建模# 线性规划问题的Matlab求解
  • (Redis使用系列) Springboot 使用redis实现接口幂等性拦截 十一
  • (ZT) 理解系统底层的概念是多么重要(by趋势科技邹飞)
  • (九)c52学习之旅-定时器
  • (五)大数据实战——使用模板虚拟机实现hadoop集群虚拟机克隆及网络相关配置
  • ***微信公众号支付+微信H5支付+微信扫码支付+小程序支付+APP微信支付解决方案总结...
  • .bat批处理(五):遍历指定目录下资源文件并更新
  • .equals()到底是什么意思?
  • .NET 3.0 Framework已经被添加到WindowUpdate
  • .net core 实现redis分片_基于 Redis 的分布式任务调度框架 earth-frost
  • .Net Core缓存组件(MemoryCache)源码解析
  • .net framwork4.6操作MySQL报错Character set ‘utf8mb3‘ is not supported 解决方法
  • .NET/C# 避免调试器不小心提前计算本应延迟计算的值
  • .NETCORE 开发登录接口MFA谷歌多因子身份验证
  • .net遍历html中全部的中文,ASP.NET中遍历页面的所有button控件
  • .NET平台开源项目速览(15)文档数据库RavenDB-介绍与初体验
  • @Controller和@RestController的区别?
  • @RequestBody的使用