Vue3中组件常用通信方式

文章目录

    • 一、Props
    • 二、v-model
    • 三、Provide/Inject:
    • 四、事件
    • 四、Ref

在 Vue 3 中,父子组件之间进行通信有多种方式,下面简单介绍下常见的方式及其用法和使用场景:

一、Props

用于父组件向子组件传递数据。
这是最基本也是最常用的一种方式。通过在子组件上定义 props,父组件可以将数据传递给子组件。在子组件中,通过 props 对象访问这些属性。
父组件

<template><ChildComponent :message="parentMessage" />
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent,},data() {return {parentMessage: 'Hello from parent!',};},
};
</script>

子组件

<template><div>{{ message }}</div>
</template><script>
export default {props: {message: String,},
};
</script>

二、v-model

用于在父子组件之间实现双向绑定。在 Vue 3 中,通过 v-model 方式进行组件通信需要使用 v-model 指令和 emit 事件。父组件使用 v-model 向子组件传递数据,并通过子组件触发 ,用update:modelValue 事件来实现双向绑定。
下面是一个简单的例子:
子组件

<!-- ChildComponent.vue -->
<template><input :value="message" @input="$emit('update:modelValue', $event)" />
</template>
<script>
export default {props: {modelValue: String,},computed: {message: {get() {return this.modelValue;},set(value) {this.$emit('update:modelValue', value);},},},
};
</script>

父组件

<!-- ParentComponent.vue -->
<template><ChildComponent v-model="parentMessage" />
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent,},data() {return {parentMessage: 'Hello from parent!',};},
};
</script>

在子组件 ChildComponent 中,通过 :value=“modelValue” 将 modelValue 绑定到 input 元素上,然后通过 @input=“$emit(‘update:modelValue’, $event)” 触发 update:modelValue 事件,从而实现了父子组件之间的双向绑定。

在父组件 ParentComponent 中,使用 v-model 将 ChildComponent 的 modelValue 绑定到 message 上,这样在父组件中修改 message 的值会自动同步到 ChildComponent 中,反之亦然。

需要注意的是,v-model 实际上是一个语法糖,它会自动处理 value 和 input 事件。如果在子组件中使用 v-model,则子组件应该接受名为 modelValue 的 prop,并发出一个名为 update:modelValue 的事件。这样可以确保 v-model 在父子组件之间正确地进行双向绑定。

三、Provide/Inject:

用于祖先组件向后代组件传递数据,通过 Provide 提供数据,通过 Inject 注入数据。祖先组件通过 provide 提供数据,后代组件通过 inject 接收数据。
祖先组件

<template><GrandparentComponent><template v-slot="{ message }"><ChildComponent :message="message" /></template></GrandparentComponent>
</template>
<script>
import GrandparentComponent from './GrandparentComponent.vue';export default {components: {GrandparentComponent,},provide() {return {message: 'Hello from grandparent!',};},
};
</script>

父组件

<template><slot :message="message" />
</template><script>
export default {inject: ['message'],
};
</script>

子组件

<template><div>{{ message }}</div>
</template><script>
export default {props: {message: String,},
};
</script>

四、事件

通过自定义事件,子组件向父组件传递数据。子组件通过 $emit 触发自定义事件,父组件监听该事件接收数据。
子组件

<template><button @click="sendMessage">Send Message</button>
</template><script>
export default {methods: {sendMessage() {this.$emit('message', 'Hello from child!');},},
};
</script>

父组件

<template><ChildComponent @message="handleMessage" />
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {components: {ChildComponent,},methods: {handleMessage(message) {console.log(message);},},
};
</script>

四、Ref

使用 ref 可以将数据在父子组件之间共享。
父组件

<template><ChildComponent :message="sharedMessage" />
</template>
<script>
import { ref } from 'vue';
import ChildComponent from './ChildComponent.vue';
export default {components: {ChildComponent,},setup() {const sharedMessage = ref('Hello from parent!');return { sharedMessage };},
};
</script>

子组件

<template><div>{{ message }}</div>
</template>
<script>
import { ref, watchEffect } from 'vue';export default {props: {message: String,},setup(props) {const message = ref(props.message);watchEffect(() => {// 监听 props 中的 message 变化message.value = props.message;});return { message };},
};
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/597151.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法导论复习——CHP16 贪心算法

定义 每一步都做出当前看来最优的操作。 问题引入——活动选择问题 问题描述 活动选择问题就是对给定的包含n个活动的集合S&#xff0c;在已知每个活动开始时间和结束时间的条件下&#xff0c;从中选出最多可兼容活动的子集合&#xff0c;称为最大兼容活动集合。 不失一般性&a…

Could not recognize scene type gaussian-splatting 常见报错

目录 render报错 GroupParams object has no attribute source_path Could not recognize scene type 报错代码: 默认路径代码:

微信小程序-监听屏幕滚动

实现&#xff1a; 运用页面Page()函数中的onPageScroll方法&#xff0c;来监听屏幕滚动的距离。 1&#xff09;.js中&#xff1a; data:{scrollTop:0, },//监听屏幕滚动 判断上下滚动onPageScroll: function (ev) {this.setData({scrollTop: ev.scrollTop})}, 2&#xff09…

Java集合-ArrayList

Java集合-ArrayList 特性 实现了三个标记接口&#xff1a;RandomAccess&#xff0c;Cloneable&#xff0c;java.io.Serializable public class ArrayList<E> extends AbstractList<E>implements List<E>, RandomAccess, Cloneable, java.io.Serializable1…

普通函数与函数模板的区别以及调用规则 学习笔记

前提知识&#xff1a; 引用是不能出现在隐式类型转换之中 引用时会把隐式类型转换后的值放到一个常量区中&#xff0c;即我们引用的时候&#xff0c;引用的是一个常量区的值。如果想使用引用&#xff0c;那么必须加const修饰&#xff0c;变成只读&#xff0c;方可使用隐式类型…

解析《个人信息保护法》实施以来主要的变化

文章目录 前言一、二十一部配套的立法二、数据入表三、跨境规则转向四、未成年个人信息保护五、数据交易六、监管创新七、执法全覆盖八、地方聚焦场景执法九、个人信息保护诉讼十、个人信息保护公益诉讼十一、包容审慎十二、双清单上线十三、外部独立监督机构十四、个性化推荐便…

建立java和sql的连接(为聊天窗口添加注册功能)

建立java和sql的连接(为聊天窗口添加注册功能) 1.1首先需要导入mysql的相关包&#xff0c;将下好的jar文件拖入在src中新建立的lib文件夹(directory)里面&#xff0c;然后将lib进行add as library就算导入成功了 2.1明确dao是什么 DAO&#xff08;Data Access Object&#x…

SVN迁移至GitLab,并附带历史提交记录(二)

与《SVN迁移至GitLab&#xff0c;并附带历史提交记录》用的 git svn clone不同&#xff0c;本文使用svn2git来迁移项目代码。 一、准备工作 安装Git环境&#xff0c;配置本地git账户信息&#xff1a; git config --global user.name "XXX" git config --global us…

计算机丢失VCRUNTIME140_1.dll怎么办,6个不同方法教你解决问题

一、什么是vcruntime140_1.dll&#xff1f; vcruntime140_1.dll是Visual C Redistributable Packages的一部分&#xff0c;它是Microsoft Visual Studio开发环境中使用的运行时库文件。它包含了许多常用的函数和类&#xff0c;为开发者提供了丰富的功能支持。 二、vcruntime1…

大数据可视化Web框架——飞致云Dataease在Windows端的安装指南(多图说明版)V2.2最新版

DataEase开源代码在Windows系统开发环境搭建与调试指南_怎么部署dataease 2.0-CSDN博客https://blog.csdn.net/tllhc01/article/details/135220598?spm1001.2014.3001.5502参考这一篇&#xff0c;基于dataease2.2源码进行构建 需要先下载三个文件&#xff0c;且版本一一对应均…

C++多态性——(4)纯虚函数与抽象类

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 我们不能选择命运&#xff0c;但我们可…

基于注解的IOC配置

基于注解的IOC配置 学习基于注解的IOC配置&#xff0c;大家脑海里首先得有一个认知&#xff0c;即注解配置和xml配置要实现的功能都是一样的&#xff0c;都是要降低程序间的耦合。只是配置的形式不一样。 1.创建工程 pom.xml <?xml version"1.0" encoding&qu…

Vault实战(三)-Vault命令详解

1 login login 命令使用提供的参数向 Vault 验证用户或机器。身份验证成功会返回一个 Vault 令牌 - 在概念上类似于网站上的会话令牌。默认情况下&#xff0c;此令牌会被缓存在本地以供将来发起请求时使用。 -method 标志允许使用其他身份验证方法&#xff0c;例如 userpass、…

MySQL之CRUD,函数与union使用

目录 一.CRUD 1.1.SELECT(查询) 1.2.INSERT&#xff08;新增&#xff09; 1.3.UPDATE(修改) 1.4.DELETE&#xff08;删除&#xff09; 二.函数 2.1.常见函数 2.1.1.字符函数 2.1.2.数字函数 2.1.3.日期函数 2.2.流程控制函数 2.3.聚合函数 三.union与union all 四…

STM32学习笔记十八:WS2812制作像素游戏屏-飞行射击游戏(8)探索游戏多样性,范围伤害模式

前面我们的攻击手段比较单一&#xff0c;虽然已经分出了 EnemyT1 / EnemyT2 / EnemyT3&#xff0c; 但里面还是基本一样的。这回&#xff0c;我们尝试实现一些新的攻击方法&#xff0c;实现一些新的算法。 1、前面我们小飞机EnemyT1 的攻击方式是垂直向下发射子弹。 那么大飞机…

Linux 安装 MySQL

一、安装 MySQL 的准备工作 1. 查看系统版本 cat /etc/redhat-release2. 查看系统是否已经安装过 MySQL 查看是否安装了 MySQL rpm -qa | grep mysql查看是否有安装 mariadb&#xff0c;该软件与 MySQL 数据库有冲突&#xff0c;需要手动卸载 # 如果是 CentOS7 可以检测出…

Scene Creator

场景创建器是一个方便、易于使用的编辑工具&#xff0c;旨在简化创建新场景的过程。使用场景创建器&#xff0c;您可以选择一个模板场景&#xff0c;定义一个目录来存储您的场景&#xff0c;并在需要时自动将新场景添加到构建中。 下载&#xff1a; ​​Unity资源商店链接 资…

什么是CHATGPT

ChatGPT是一个基于大型变换器模型&#xff08;Transformer model&#xff09;的对话AI&#xff0c;它通过机器学习的方法训练&#xff0c;能够生成人类般的文本。GPT&#xff08;Generative Pre-trained Transformer&#xff09;是由OpenAI开发的&#xff0c;其中“GPT”表示模…

vue3安装vue-tools

https://github.com/vuejs/devtools/tree/v6.5.0/packages 打开浏览器扩展程序 这个文件直接拖进扩展程序

【Python】Python函数isalnum用法介绍

本文将从多个方面详细阐述Python函数isalnum的使用方法及其内部实现原理。 一、函数及其作用 isalnum()函数是Python中的一个内置函数&#xff0c;用于判断字符串是否只由数字和字母组成。如果是&#xff0c;则返回True&#xff0c;否则返回False。 str.isalnum() 其中&…