news 2026/6/21 18:33:59

vue3中v-model 用法详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
vue3中v-model 用法详解

一、v-model的本质

v-model本质上是一个语法糖,用于实现:

  • 父组件向子组件传值

  • 子组件向父组件回传更新

在 Vue 3 中,v-model默认等价于:

:modelValue="xxx" @update:modelValue="xxx = $event"

二、基础用法(表单元素)

1. 文本输入框

<input v-model="username" />

等价于:

<input :value="username" @input="username = $event.target.value" />

2. 常见表单绑定

表单类型示例
text<input v-model="text" />
checkbox<input type="checkbox" v-model="checked" />
radio<input type="radio" value="A" v-model="picked" />
select<select v-model="selected">
textarea<textarea v-model="msg"></textarea>

三、组件上的v-model(核心重点)

1. Vue 3 默认规则(强烈推荐)

子组件
<script setup> defineProps({ modelValue: String }) const emit = defineEmits(['update:modelValue']) </script> <template> <input :value="modelValue" @input="emit('update:modelValue', $event.target.value)" /> </template>
父组件
<Child v-model="username" />

2. 等价展开写法(理解用)

<Child :modelValue="username" @update:modelValue="username = $event" />

四、自定义v-model参数(Vue 3 新特性)

1. 父组件

<Child v-model:title="title" />

2. 子组件

<script setup> defineProps({ title: String }) const emit = defineEmits(['update:title']) </script> <template> <input :value="title" @input="emit('update:title', $event.target.value)" /> </template>

五、多个v-model(非常实用)

父组件

<Child v-model:title="title" v-model:content="content" />

子组件

<script setup> defineProps({ title: String, content: String }) const emit = defineEmits([ 'update:title', 'update:content' ]) </script>

六、v-model修饰符(.trim/.number等)

1. 使用方式

<Child v-model:title.trim="title" />

2. 子组件接收修饰符

<script setup> const props = defineProps({ title: String, titleModifiers: { default: () => ({}) } }) </script>

3. 使用修饰符

if (props.titleModifiers.trim) { value = value.trim() }

七、在computed中使用v-model(双向绑定)

const value = computed({ get() { return props.modelValue }, set(val) { emit('update:modelValue', val) } })

模板中直接使用:

<input v-model="value" />

八、v-model与 Vue 2 的核心差异

项目Vue 2Vue 3
默认 propvaluemodelValue
默认事件inputupdate:modelValue
多 v-model不支持支持
修饰符内置可自定义
语法固定更灵活

九、最佳实践(工程经验)

  1. 组件统一使用modelValue

  2. 始终通过emit修改值

  3. 避免在子组件中直接修改 props

  4. 多字段表单优先使用多个 v-model

  5. 复杂逻辑用computed封装 v-model


十、完整示例(可直接复制)

父组件

<script setup> import { ref } from 'vue' import MyInput from './MyInput.vue' const username = ref('') </script> <template> <MyInput v-model="username" /> <p>{{ username }}</p> </template>

子组件MyInput.vue

<script setup> defineProps({ modelValue: String }) const emit = defineEmits(['update:modelValue']) </script> <template> <input :value="modelValue" @input="emit('update:modelValue', $event.target.value)" /> </template>
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/21 19:49:58

Linux线程操作全指南

Linux线程概述与操作指南线程与进程对比线程是轻量级进程&#xff0c;属于某个进程&#xff0c;共享进程资源但拥有独立栈区&#xff08;默认8MB&#xff09;。进程资源独立&#xff0c;稳定性更高&#xff1b;线程崩溃可能导致整个进程崩溃。线程创建开销更小&#xff08;仅需…

作者头像 李华
网站建设 2026/6/21 16:41:13

传统VS智能:DBC文件处理效率对比实验

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个DBC文件处理效率对比工具。工具应能&#xff1a;1) 自动生成测试用DBC文件 2) 提供传统手动解析方法 3) 实现AI自动解析方法 4) 记录并对比两种方法的处理时间和准确性。输…

作者头像 李华
网站建设 2026/6/21 5:56:31

LobeChat能否支持生物识别?人脸/声纹/步态特征分析应用

LobeChat能否支持生物识别&#xff1f;人脸/声纹/步态特征分析应用 在智能设备日益渗透日常生活的今天&#xff0c;用户对AI助手的期待早已超越“能聊天”的基础功能。我们希望它认识我、理解我&#xff0c;甚至在我开口之前就知道我想做什么——这种“感知型交互”正成为下一代…

作者头像 李华
网站建设 2026/6/21 13:43:14

Miniconda实现Python多版本灵活切换

Miniconda 实现 Python 多版本灵活切换 在机器学习和科学计算的日常开发中&#xff0c;你是否也曾陷入这样的“环境地狱”&#xff1f;&#x1f631; “这个项目用 PyTorch 1.13&#xff0c;必须 Python 3.9&#xff0c;但我的系统是 3.11。”“同事跑通的代码&#xff0c;我一…

作者头像 李华
网站建设 2026/6/21 4:33:02

场馆预约小程序开发:解锁 “预约经济” 的高效解决方案

在数字化转型加速的背景下&#xff0c;场馆预约需求已渗透体育、办公、教育、文旅等多个领域。传统线下预约模式存在 “信息不透明、操作繁琐、管理低效” 等痛点&#xff0c;而小程序凭借 “轻量化、高触达、易操作” 的优势&#xff0c;成为场馆预约场景的理想载体。本文从核…

作者头像 李华
网站建设 2026/6/21 5:01:46

Product Hunt 每日热榜 | 2025-12-16

1. Unloop 标语&#xff1a;为注意力缺陷多动症&#xff08;ADHD&#xff09;和神经多样性思维者设计的视觉模式映射 介绍&#xff1a;Unloop 是一款可视化的模式映射工具&#xff0c;帮助你识别那些让你感到陷入困境的触发因素、想法、情绪和行为。把这些内容可视化&#xf…

作者头像 李华