深入解析 Vue 3 中 v-model 与表单元素的绑定机制

v-model 是 Vue 中最强大的指令之一,它简化了表单数据双向绑定的实现。本文将系统梳理各种 HTML 表单元素与 v-model 的绑定关系,特别是那些容易引起困惑的类型。

一、v-model 的本质

v-model 是一个语法糖,它实际上是 :value 和 @input 的组合(对于大多数元素)。在 Vue 3 中,这个机制变得更加灵活和强大。

<!-- 等价关系 -->
<input v-model="text">
<!-- 等同于 -->
<input :value="text" @input="text = $event.target.value">

二、文本输入类元素

1. 普通文本输入 (type="text")

绑定值value 属性
触发事件input 事件

<input type="text" v-model="message">
<!-- 等价于 -->
<input type="text" :value="message" @input="message = $event.target.value"
>

2. 多行文本 (textarea)

绑定值value 属性
触发事件input 事件

<textarea v-model="content"></textarea>

注意:<textarea>{{ content }}</textarea> 这种插值语法不会生效。

三、选择类元素

1. 单选框 (type="radio")

这是最容易引起困惑的表单元素之一。

绑定值checked 状态
触发事件change 事件
特殊机制:通过比较 v-model 绑定的值和 value 属性来决定是否选中

<input type="radio" value="yes" v-model="answer"> 是
<input type="radio" value="no" v-model="answer"> 否

等效于: 

<input type="radio" value="yes" :checked="answer==='yes'" @change="answer='yes'"> 是
<input type="radio" value="no"  :checked="answer==='no'" @change="answer='no'"> 否

 

关键点

  • 同一组的 radio 必须绑定相同的 v-model

  • v-model 绑定的值会与每个 radio 的 value 进行比较

  • 匹配时自动设置 checked 属性

  • 用户选择时会将该 radio 的 value 赋给绑定的变量

类型转换

  • 默认将 value 视为字符串

  • 如果需要其他类型,使用 :value 绑定:

    <input type="radio" :value="true" v-model="isAgree"> 同意

2. 复选框 (type="checkbox")

分为单个和多个两种情况。

单个复选框:

绑定值checked 状态
触发事件change 事件
绑定类型:布尔值

<input type="checkbox" v-model="isChecked">
<!-- 等价于 -->
<input type="checkbox" :checked="isChecked" @change="isChecked = $event.target.checked"
>
多个复选框(数组绑定):

绑定值checked 状态
触发事件change 事件
绑定类型:数组

<input type="checkbox" value="vue" v-model="skills"> Vue
<input type="checkbox" value="react" v-model="skills"> React

选中时,value 会被添加到数组中,取消选中时移除。

3. 下拉选择框 (select)

单选:

绑定值:选中的 option 的 value
触发事件change 事件

<select v-model="selectedCity"><option value="bj">北京</option><option value="sh">上海</option>
</select>
多选(添加 multiple 属性):

绑定值:所有选中 option 的 value 数组
触发事件change 事件

<select v-model="selectedCities" multiple><option value="bj">北京</option><option value="sh">上海</option>
</select>

四、特殊输入类型

1. 数字输入 (type="number")

绑定值valueAsNumber 或 value
触发事件input 事件
类型转换:自动转换为 Number 类型

<input type="number" v-model="age">

2. 范围滑块 (type="range")

绑定值value 属性
触发事件input 事件

<input type="range" v-model="volume" min="0" max="100">

3. 日期时间输入 (type="date"type="time" 等)

绑定值value 属性(格式化为字符串)
触发事件input 事件

<input type="date" v-model="birthday">

五、自定义组件的 v-model

在 Vue 3 中,自定义组件的 v-model 行为有了重大变化:

<CustomInput v-model="searchText" />
<!-- 等价于 -->
<CustomInput :modelValue="searchText"@update:modelValue="newValue => searchText = newValue"
/>

可以在组件中通过 defineProps 和 defineEmits 来处理:

// 子组件
const props = defineProps(['modelValue'])
const emit = defineEmits(['update:modelValue'])

六、最佳实践与常见问题

  1. 类型一致性:确保 v-model 绑定的变量类型与 value 类型匹配

  2. 性能考虑:对于大型表单,考虑使用 lazy 修饰符减少更新频率

    <input v-model.lazy="message">
  3. 修饰符

    • .number:自动将输入转为数字

    • .trim:自动去除首尾空格

七、总结对比表

元素类型绑定属性触发事件绑定值类型特殊说明
text, textareavalueinputstring-
radiocheckedchangeany比较 value 和绑定值
checkbox (单个)checkedchangeboolean-
checkbox (多个)checkedchangearray收集所有选中的 value
select (单选)valuechangeany匹配 option 的 value
select (多选)valuechangearray收集所有选中的 value
numbervalueAsNumberinputnumber自动类型转换
rangevalueinputnumber/string-
date/timevalueinputstring使用标准格式 (YYYY-MM-DD)

理解这些绑定差异将帮助您更高效地使用 Vue 处理表单逻辑,避免常见的陷阱。特别是在处理 radio 和 checkbox 时,明确绑定机制可以节省大量调试时间。

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

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

相关文章

【赵渝强老师】MySQL中的数据库对象

MySQL数据库中包含各自数据库对象&#xff0c;常见的数据库对象有&#xff1a;表、索引、视图、事件、存储过程和存储函数等等。 视频讲解如下 【赵渝强老师】MySQL中的数据库对象一、 创建与管理表 表是一种非常重要的数据库对象&#xff0c;MySQL数据库的数据都是存储在表中…

Angular面试题目和答案大全

基础概念篇1. 什么是Angular&#xff1f;它与AngularJS有什么区别&#xff1f;答案&#xff1a; Angular是由Google开发的基于TypeScript的开源Web应用框架&#xff0c;用于构建单页应用程序&#xff08;SPA&#xff09;。Angular vs AngularJS对比&#xff1a;特性AngularJSAn…

CSS 语音参考

CSS 语音参考 概述 CSS&#xff08;层叠样式表&#xff09;是用于描述HTML或XML文档样式的样式表语言。它为网页元素提供了一种统一的方式来定义字体、颜色、布局和其他视觉属性。CSS语音参考旨在为开发者提供一个详尽的指南&#xff0c;以便他们能够更有效地使用CSS来增强网页…

C# WPF 实现读取文件夹中的PDF并显示其页数

文章目录技术选型第一步&#xff1a;创建项目并安装依赖库第二步&#xff1a;定义数据模型 (Model)第三步&#xff1a;创建视图模型 (ViewModel)第四步&#xff1a;设计用户界面 (View)总结与解释后记关于转换器的错误工作中需要整理一些PDF格式文件&#xff0c;程序员的存在就…

设计模式(五)创建型:原型模式详解

设计模式&#xff08;五&#xff09;创建型&#xff1a;原型模式详解原型模式&#xff08;Prototype Pattern&#xff09;是 GoF 23 种设计模式中的创建型模式之一&#xff0c;其核心价值在于通过复制现有对象来创建新对象&#xff0c;而不是通过 new 关键字调用构造函数。它特…

K8S 八 数据存储-高级存储PV PVC 生命周期;配置存储ConfigMap Secret

目录数据存储 Volume8.1 基本存储8.1.1 EmptyDir8.1.2 HostPath 挂载目录8.1.3 NFSnfs的服务8.2 高级存储8.2.1 PV和PVC8.2.2 PV 持久化卷申请8.2.3 PVC 资源申请PVC的配置参数8.2.4 生命周期配置存储8.3.1 ConfigMap8.3.2 Secret数据存储 Volume Kubernetes的Volume支持多种类…

Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现轮船检测识别(C#代码UI界面版)

Baumer工业相机堡盟工业相机如何通过YoloV8深度学习模型实现轮船检测识别&#xff08;C#代码UI界面版&#xff09;工业相机使用YoloV8模型实现轮船检测识别工业相机通过YoloV8模型实现轮船检测识别的技术背景在相机SDK中获取图像转换图像的代码分析工业相机图像转换Bitmap图像格…

自习室预约小程序的设计与实现

自习室预约小程序的设计与实现现代学习环境对高效、便捷的预约系统需求日益增长。自习室预约小程序结合前沿技术栈&#xff0c;提供流畅的用户体验和强大的后台管理功能&#xff0c;满足学生、职场人士等群体的自习需求。技术架构与核心功能Vue.js 构建动态前端界面 采用 Vue.j…

Docker 实战大纲

文章目录Docker 实战 – Mysql &#xff08;敬请期待……&#xff09;

从一个“诡异“的C++程序理解状态机、防抖与系统交互

引言 在编程世界中&#xff0c;有时一个看似简单的代码片段可能隐藏着令人惊讶的复杂性。本文将从一个"故意设计"的C程序出发&#xff0c;深入探讨其背后涉及的状态机模式、防抖机制以及操作系统与控制台的交互原理。通过这个案例&#xff0c;我们不仅能理解这些核心…

NAS-Bench-101: Towards Reproducible Neural Architecture Search

概述这篇题为"NAS-Bench-101: Towards Reproducible Neural Architecture Search"的论文由Chris Ying等人合作完成&#xff0c;旨在解决神经网络架构搜索(NAS)领域面临的重大挑战&#xff1a;计算资源需求高和实验难以复现的问题。论文提出了NAS-Bench-101&#xff0…

SpringBoot整合Fastexcel/EasyExcel导出Excel导出多个图片

整个工具的代码都在Gitee或者Github地址内 gitee&#xff1a;solomon-parent: 这个项目主要是总结了工作上遇到的问题以及学习一些框架用于整合例如:rabbitMq、reids、Mqtt、S3协议的文件服务器、mongodb、xxl-job、powerjob还有用Docker compose部署各类中间组件。如果大家有…

网络原理--HTTPHTTPS

目录 一、HTTP 1.1 HTTP是什么 1.2 HTTP协议的工作过程 1.3 HTTP协议格式 1.3.1 抓包工具的使用 1.3.2 抓包结果 1.4 HTTP请求 1.4.1 URL 1.4.2 认识“方法” (method) 1.4.3 认识请求“报头”(header) 1.4.4 认识请求“正文”(body) 1.5 HTTP 响应详解 1.5.1 HTTP…

『 C++ 入门到放弃 』- 哈希表

一、哈希的概念 哈希&#xff0c;也称「 散列 」是一种用来进行高效查找的数据结构&#xff0c;查找的时间复杂度平均为O(1)&#xff0c;其本质就是依赖哈希函数这个算法来将 key 和该 key 存储位置建立一个映射关系。 而因为是有着映射关系&#xff0c;所以哈希的事件复杂度为…

零售收银系统开源代码全解析:连锁门店一体化解决方案(含POS+进销存+商城)

过去10年&#xff0c;收银系统技术经历了从单机版到云服务、从单纯结算到全渠道整合的快速演进。面对连锁多门店、AI称重、智能分账、跨店库存同步等新需求&#xff0c;很多企业的现有传统saas系统已显乏力。本文将梳理收银系统关键技术指标&#xff0c;助您在系统升级时做出明…

能源高效利用如何实现?楼宇自控系统智能化监管建筑设备

随着全球能源危机日益严峻和“双碳”目标的持续推进&#xff0c;建筑领域作为能耗大户&#xff08;约占社会总能耗的40%&#xff09;&#xff0c;其节能潜力备受关注。楼宇自控系统&#xff08;Building Automation System&#xff0c;简称BAS&#xff09;作为建筑智能化的核心…

校园二手交易小程序的设计与实现

文章目录前言详细视频演示具体实现截图后端框架SpringBoot微信小程序持久层框架MyBaits成功系统案例&#xff1a;参考代码数据库源码获取前言 博主介绍:CSDN特邀作者、985高校计算机专业毕业、现任某互联网大厂高级全栈开发工程师、Gitee/掘金/华为云/阿里云/GitHub等平台持续…

Redis(二):Redis高级特性和应用(慢查询、Pipeline、事务)

Redis的慢查询 许多存储系统&#xff08;例如 MySQL)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作。所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间&#xff0c;当超过预设阀值,就将这条命令的相关信息&#xff08;例如:发生时间&#xff0c;耗时&…

如何为你的WordPress网站选择合适的安全插件

在管理WordPress网站时&#xff0c;安全因素至关重要。由于WordPress的广泛使用&#xff0c;它也成为了黑客攻击的首要目标。为了避免潜在的安全风险&#xff0c;选择合适的安全插件至关重要。而Wordfence和iThemes&#xff0c;作为两款颇具人气的WordPress安全插件&#xff0c…

我们使用Rust开发的AI知识库应用

这段时间陆陆续续的开发了2个AI知识库应用&#xff0c;一个面向企业&#xff0c;一个面向C端用户。 飞树智库&#xff1a;一个安全高效的面向 企业的知识库平台&#xff08;https://fskb.coderbox.cn/&#xff09;。 小飞树&#xff1a;一个专注于个人知识管理的AI应用&#…