Vue 3 中使用 const model=defineModel() 简化 v-model 的技巧

当我们在 Vue 3 中处理表单输入时,经常会使用 v-model 来实现数据的双向绑定。然而,在某些情况下,我们可能需要对 v-model 进行一些额外的处理,例如对输入值进行格式化、验证或者其他操作。这时,可以使用 const model = defineModel(); 来简化 v-model 的使用,并使代码更加清晰和易于维护。

问题背景

在 Vue 3 中,当我们想要创建一个带有自定义逻辑的双向绑定输入框时,通常会这样写:

<template><el-select style="width:100%;" :size="styleSize" clearable filterable @change="changeData" v-model="selectValue"placeholder="请选择"><el-optionv-for="item in options":key="item.dataCode":label="item.dataCode":value="item.dataValue"></el-option></el-select>
</template><script>
export default {name: "nb-select",props: ['value', "catalog", "size"],data: function () {return {selectValue: "",loading: false,options: [],styleSize: "normal"}},mounted: function () {console.info("init");this.loadData();this.selectValue = this.value;if (this.size != null && this.size != "") {this.styleSize = this.size;}},watch: {value: function (val) {this.selectValue = val;}},methods: {async loadData() {let param = {};param.dictKey = this.catalog;let res = await this.$http.form("/dictItem/list", param);if (res.code === 200) {this.options = res.data;}},changeData(value) {console.info(value);this.$emit('input', value);}}
}
</script><style scoped></style>

这种方式虽然可以实现双向绑定,但是当涉及到多个输入框时,代码会显得重复而冗长。

使用 const model = defineModel();

Vue 3 提供了一个工具函数 defineModel(),它可以帮助我们简化 v-model 的使用,并更好地组织代码。

<template><el-select style="width:100%;"   clearable filterable  v-model="model" ><el-optionv-for="item in options":key="item.dataCode":label="item.dataCode":value="item.dataValue"></el-option></el-select>
</template><script setup>
import {useLoadData} from "@/uses/useLoadData";const model=defineModel();
const props=defineProps({dictKey: {type: String,default: ""}
})let param = {dictKey: props.dictKey,
};
const {data:options}= useLoadData("/dictItem/list",param);</script><style scoped></style>

通过上面的代码,我们可以看到 const model = defineModel(); 的用法。这里的 model 就相当于我们之前手动创建的 inputValue,但它更加灵活和通用。

defineModel() 的优势

  • 简化代码:使用 const model = defineModel(); 可以减少重复的代码,使得代码更加简洁清晰。
  • 更好的组织代码:将 v-model 的处理逻辑统一到一个地方,便于维护和管理。
  • 灵活性defineModel() 可以处理任意类型的输入,包括表单输入、复杂组件等。

示例:自定义输入框组件

下面是一个简单的示例,展示如何使用 const model = defineModel(); 创建一个自定义的输入框组件,并添加了一些自定义的逻辑:

<template><input:value="model"@input="handleInput"@blur="handleBlur"/>
</template><script setup>
import { defineModel } from 'vue';const model = defineModel();// 处理输入事件
const handleInput = (event) => {const newValue = event.target.value.toUpperCase(); // 将输入值转换为大写model.value = newValue;
};// 处理失焦事件
const handleBlur = () => {console.log('Input blurred');
};
</script>

在这个示例中,我们使用 const model = defineModel(); 来简化双向绑定,同时添加了自定义的输入处理逻辑和失焦处理逻辑。

总体来说,const model = defineModel(); 是一个非常方便的工具函数,能够帮助我们更好地处理 v-model,简化代码,提高开发效率。在实际开发中,可以根据需要结合自定义逻辑,更灵活地处理表单输入和其他交互操作。

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

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

相关文章

搜歌网搜索各种类型音乐,统统歌曲转换格式mp3,轻松实现音乐自由!

在互联网的广阔天地中&#xff0c;音乐爱好者们总能找到满足自己需求的平台。其中&#xff0c;支持全网搜歌的网站无疑是一个值得推荐的音乐探索乐园。无论是寻找经典老歌&#xff0c;还是发掘新兴音乐&#xff0c;搜他们都能为音乐爱好者提供一站式的服务。 一般支持全网搜索…

值得收藏!!《软考信息处理技术员》必背100母题,轻松45+

距离软考考试的时间越来越近了&#xff0c;趁着这两周赶紧准备起来 今天给大家整理了——软考信息处理技术员100道经典母题&#xff0c;年年从里面抽&#xff0c;有PDF&#xff0c;可打印&#xff0c;每天刷几道。 第一章 电脑的基本操作 1、&#xff08; &#xff09;不是国产…

Linux线程(二)线程互斥

目录 一、为什么需要线程互斥 二、线程互斥的必要性 三、票务问题举例&#xff08;多个线程并发的操作共享变量引发问题&#xff09; 四、互斥锁的用法 1.互斥锁的原理 2、互斥锁的使用 1、初始化互斥锁 2、加锁和解锁 3、销毁互斥锁&#xff08;动态分配时需要&#…

在AWS EKS中使用Socket.IO

背景 需要在K8S集群中提供websocket服务。后端使用的是netty-socketio库实现了Socket.IO方式的ws服务。前端直接使用Socket.IO 客户端js实现。这里重点介绍AWS EKS中怎么通过启用ALB粘性会话的方式支持ws服务。 svc.yaml apiVersion: v1 kind: Service metadata:labels:app:…

RFID在汽车制造中的应用如何改变行业

随着工业4.0和中国制造2025的推进&#xff0c;企业对于智能化、自动化的需求日益增长&#xff0c;RFID射频技术在制造业中已经相当普遍了。在如今这瞬息万变的行业与时代中&#xff0c;RFID技术可以帮助企业获得竞争优势&#xff0c;简化日益复杂的生产流程&#xff0c;推动企业…

C语言实战项目---通讯录

项目要实现的内容&#xff1a;能够存放100个人的通讯录程序&#xff0c;能够实现联系人数据的存储&#xff0c;删除&#xff0c;修改&#xff0c;查找&#xff0c;展示联系人的信息。 所需知识&#xff1a;结构体&#xff0c;指针&#xff0c;函数................. 废话不多…

2016-2021年全国范围的2.5m分辨率的建筑屋顶数据

一、论文介绍 摘要&#xff1a;大规模且多年的建筑屋顶面积&#xff08;BRA&#xff09;地图对于解决政策决策和可持续发展至关重要。此外&#xff0c;作为人类活动的细粒度指标&#xff0c;BRA可以为城市规划和能源模型提供帮助&#xff0c;为人类福祉带来好处。然而&#xf…

Qt之常用控件一

Widget常见属性及其作用 属性作用enabled 设置控件是否可使⽤. true 表⽰可⽤, false 表⽰禁⽤ geometry 位置和尺⼨. 包含 x, y, width, height 四个部分. 其中坐标是以⽗元素为参考进⾏设置的. windowTitle 设置 widget 标题 windowIcon 设置 widget 图标 windowOpa…

java日历类概述

Java中的Calendar类位于java.util包下&#xff0c;它是一个抽象类&#xff0c;用于表示和管理日期及时间。Calendar类并不是直接实例化的&#xff0c;而是通过其提供的静态方法来获取实例。通常情况下&#xff0c;当你尝试创建一个Calendar实例时&#xff0c;实际上你得到的是G…

The 2023 ICPC Asia Hefei Regional Contest

目录 B. Queue Sorting 应该还会再补几题 B. Queue Sorting 题解&#xff1a; Dilworth定理: 【偏序关系与偏序集、Hasse图、极大元、极小元、全序关系、最大元、良序集/三小时讲不完离散数学之集合论/考研复试/期末复习考前冲刺/近世代数/抽象代数】https://www.bilibili.c…

C++奇迹之旅:string类对象的容量操作

文章目录 &#x1f4dd; string类的常用接口&#x1f309; string类对象的容量操作&#x1f320;size&#x1f320;length&#x1f320;capacity&#x1f320;clear&#x1f320;empty&#x1f320;reserve&#x1f309;resize &#x1f6a9;总结 &#x1f4dd; string类的常用…

JavaScript进阶2

自定义对象 let 自定义对象名{ 属性名:属性值, 函数名称:function(形参列表){} }; 注意&#xff1a;在自定义对象中使用当前自定义对象的属性或者函数&#xff0c;需要使用this <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-…

PMP有效期三年后,还有必要续证吗?

通常情况下是必要的&#xff0c;续证条件是在3年内累积60个PDU和支付150美元。如果到期后没有进行续证&#xff0c;但仍希望保持证书&#xff0c;就需要重新参加PMP考试。重新参加考试的费用包括3900元的报名费和数千元的培训费。因此&#xff0c;与重新考试相比&#xff0c;续…

面向过程和面向对象

面向过程和面向对象的概念及区别 面向过程&#xff1a; 概念&#xff1a; 面向过程是一种以事件为中心的编程范式。它按照功能将程序结构划分为若干个基本模块&#xff0c;形成树状结构。每个模块内部一般由顺序、选择和循环三种基本结构组成。 特点&#xff1a; 程序流程在编…

实现ApplicationContextAware接口完成springboot项目的初始化处理工作

需求&#xff1a;在项目启动的时候&#xff0c;从数据库里取出所有敏感词&#xff0c;放到map里面。 ApplicationContextAware 的实现类的setApplicationContext方法可以获取到IOC容器&#xff0c;虽然这个案例里面并没有什么用&#xff0c;但是项目初始化一般实现ApplicationC…

C++中rand()函数和随机数种子

C中rand()函数的用法 rand() % (b-a1) a ; 就表示 a~b 之间的一个随机整数。 表达式 int num rand() % 100 1; 产生的是1到100之间的随机数&#xff0c;而不是1到99。 rand() % 100 会产生一个从0到99的随机数&#xff0c;因为 % 是取模运算符&#xff0c;它会给出 rand() …

【算法刷题day49】Leetcode:123.买卖股票的最佳时机III、188. 买卖股票的最佳时机 IV

文章目录 Leetcode 123.买卖股票的最佳时机III解题思路代码总结 Leetcode 188. 买卖股票的最佳时机 IV解题思路代码总结 草稿图网站 java的Deque Leetcode 123.买卖股票的最佳时机III 题目&#xff1a;123.买卖股票的最佳时机III 解析&#xff1a;代码随想录解析 解题思路 定…

【AI】人工智能的应用及挑战

AI是人工智能&#xff08;Artificial Intelligence&#xff09;的缩写&#xff0c;它是一种模拟人类智能的技术和系统&#xff0c;旨在使计算机能够模仿人类的思维、学习、推理、理解自然语言&#xff0c;并能执行各种任务。AI利用大数据、机器学习、模式识别、自然语言处理等技…

通过 Java 操作 redis -- 基本通用命令

目录 使用 String 类型的 get 和 set 方法 使用通用命令 exists &#xff0c;del 使用通用命令 keys 使用通用命令 expire,ttl 使用通用命令 type 要想通过 Java 操作 redis&#xff0c;首先要连接上 redis 服务器&#xff0c;推荐看通过 Java 操作 redis -- 连接 redis 关…

思维导图在线怎么制作?推荐这些工具

思维导图在线怎么制作&#xff1f;在如今的快节奏时代中&#xff0c;思维导图作为一种高效的信息组织与思考工具&#xff0c;受到了广泛的应用。在线制作思维导图成打破了时间和空间的限制&#xff0c;使得团队协作变得更加便捷&#xff0c;个人创作也更为灵活。以下是四款备受…