Vue3.4 中 v-model 双向数据绑定新玩法详解

server/2024/9/23 20:25:30/

随着 Vue3.4 版本的发布,defineModel 也正式转正了。它可以简化父子组件之间的双向绑定,是目前官方推荐的双向绑定实现方式。

之前在 Vue3.3 中,该方法还是实验性方法,使用 defineModel 需在 vite.config.ts 里面配置 defineModel 为 true,配置如下:

javascript">export default defineConfig({plugins: [vue({script: {defineModel: true,},}),],
});

但 Vue3.4 版本中已经是稳定特性了!!!

正式介绍 defineModel

defineModel 是一个新的 <script setup> 宏,旨在简化支持 v-model 的组件的实现, 这个宏用来声明一个双向绑定 prop,通过父组件的 v-model 来使用。

它之前作为实验性功能在 Vue3.3 中发布,并在 Vue3.4 中升级为稳定状态。现在,它还为 v-model修饰符的使用提供了更好的支持。

defineModel 使用

例举一个最简单的使用场景: 自定义组件中使用 v-model 来进行数据的双向绑定。

javascript"><!-- 父组件 -->
<template><div><!-- 自定义子组件 CustomComponent 使用 v-model 指令绑定 userName --><CustomComponent v-model="userName" /></div>
</template><script setup>
import { ref } from "vue";
import CustomComponent from "./CustomComponent.vue";const userName = ref("前端开发爱好者");
</script>

在 Vue3.3 版本之前,我们通常通过 props 接收 modelValue,然后在更新时,我们会将更新后的值传递给 emit 的 update:modelValue 并执行:

javascript"><!-- 子组件 CustomComponent  -->
<template><input:value="props.modelValue"@input="emit('update:modelValue', $event.target.value)"/>
</template><script setup>
import { defineProps, defineEmits } from "vue";const props = defineProps(["modelValue"]);const emit = defineEmits(["update:modelValue"]);
</script>

Vue3.4 版本之后,我们将使用 defineModel 替代子组件中的 props 和 emit

javascript"><!-- 子组件 CustomComponent  -->
<template><input type="text" v-model="modelValue" />
</template><script setup>
const modelValue = defineModel();
</script>

带参数/定义多个 v-model

组件中可以支持定义多个 defineModel,可以满足绑定多个双向绑定的属性。

javascript"><!-- 父组件 -->
<template><div><!-- 自定义子组件 CustomComponent 使用 v-model 指令绑定 userName --><CustomComponentv-model="userName"v-model:title="title"v-model:subTitle="subTitle"/></div>
</template><script setup>
import { ref } from "vue";
import CustomComponent from "./CustomComponent.vue";const userName = ref("前端开发爱好者");
const title = ref("前端开发爱好者_title");
const subTitle = ref("前端开发爱好者_subTitle");
</script>

修饰符和转换器

为了获取 v-model 指令使用的修饰符,我们可以像这样解构 defineModel() 的返回值:

javascript">const [modelValue, modelModifiers] = defineModel()// 对应 v-model.trim
if (modelModifiers.trim) {// ...
}

当存在修饰符时,我们可能需要在读取或将其同步回父组件时对其值进行转换。我们可以通过使用 get 和 set 转换器选项来实现这一点:

javascript">const [modelValue, modelModifiers] = defineModel({// get() 省略了,因为这里不需要它set(value) {// 如果使用了 .trim 修饰符,则返回裁剪过后的值if (modelModifiers.trim) {return value.trim()}// 否则,原样返回return value}
})

http://www.ppmy.cn/server/120970.html

相关文章

高胜率开仓策略解析|三步建仓法

做交易无论是采用何种交易系统或策略&#xff0c;开仓作为交易的第一步&#xff0c;其重要性都是可想而知的。俗话说“一个好的开头是成功的一半”&#xff0c;在交易中&#xff0c;一个精准的开仓往往能提升交易的成功率。今天&#xff0c;我们就以开仓为核心&#xff0c;深入…

2-99 基于matlab多尺度形态学提取眼前节组织

基于matlab多尺度形态学提取眼前节组织&#xff0c;通过应用不同尺度的结构元素进行边缘检测&#xff0c;再通过加权融合的思想来整合检测到的边缘&#xff0c;降低图像噪声的影响&#xff0c;提高边缘检测的精度。程序已调通&#xff0c;可直接运行。 下载源程序请点链接&…

设计模式——对象池模式

对象池模式 1. 概述2. 适用场景3. 原理4. 优点5. 缺点 示例代码示例代码使用示例 Java 标准库中的例子Apache Commons Pool 示例 1. 概述 对象池模式&#xff08;Object Pool Pattern&#xff09; 是一种用于管理和复用一组预先创建的对象的设计模式。它的主要目的是为了提高性…

1.《DevOps》系列K8S部署CICD流水线之部署K8S集群~version1.28.2

架构 服务器IP服务名称硬件配置192.168.1.100k8s-master8核、16G、120G192.168.1.101k8s-node18核、16G、120G192.168.1.102k8s-node28核、16G、120G192.168.1.103nfs2核、4G、500G 操作系统&#xff1a;Rocky9.3 后续通过K8S部署GitLab、Harbor、Jenkins 一、环境准备 关…

2024“华为杯”中国研究生数学建模竞赛(A题)深度剖析_数学建模完整过程+详细思路+代码全解析

问题一详细解答过程 2. 简化疲劳损伤计算模型 2.1 累积损伤的Palmgren-Miner理论 根据Palmgren-Miner线性累积损伤理论&#xff0c;疲劳损伤是通过在一定的应力循环下累积的。对于给定应力幅值 S i S_i Si​&#xff0c;累积损伤值 D D D 是由经历的应力循环次数 n i n_i…

C语言编译四大阶段

目录 一、引言 二、预处理阶段 三、编译阶段 四、汇编阶段 五、链接阶段 六、总结 本文将详细介绍C语言编译的四个阶段&#xff0c;包括预处理、编译、汇编和链接。通过学习这些阶段&#xff0c;读者可以更好地理解C语言程序的编译过程&#xff0c;提高编程效率。 一、引…

saltstack企业实战

saltstack官网最新文档 saltstack架构设计 saltstack 高可用方案&#xff1a;Salt官网是有 HARebalance minion配置里写多个master地址 failover&#xff08;syndic&#xff09; 架构 操作系统&#xff1a;CentOS7.6salt版本&#xff1a;3000.3 多master https://www.cn…

Docker学习笔记(四)单主机网络

简介 Docker从容器中抽象除出了底层的主机连接网络&#xff0c;使得程序不用关心运行时的环境。连接到Docker网络的容器将获得唯一的地址&#xff0c;其他连接到同一Docker网络的容器也可以根据该IP找到目标容器并发送消息。   但是容器内运行的软件没法方便的确定主机IP地址…