news 2026/4/16 9:19:55

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/4/14 15:36:21

Tarjan算法图论全家桶系列--边双联通分量(eDCC)

边双联通分量(eDCC) 定义 在无向图G(V,E)中&#xff0c;如果删除任意一条边后&#xff0c;子图仍然连通&#xff0c;则称这个子图是边连通的。 边双连通分量&#xff08;Edge Biconnected Component, eDCC&#xff09;&#xff1a;图的极大边连通子图。 重要性质&#xff1a; 边…

作者头像 李华
网站建设 2026/4/16 9:18:52

Langchain-Chatchat集成华为NPU与MindIE部署实战

Langchain-Chatchat集成华为NPU与MindIE部署实战 在企业级AI应用落地的浪潮中&#xff0c;如何构建一个既安全可控、又高效稳定的私有化智能问答系统&#xff0c;正成为金融、政务和大型集团关注的核心命题。尤其是在数据合规日益严格的背景下&#xff0c;将大模型能力部署于本…

作者头像 李华
网站建设 2026/4/12 2:55:42

智慧物流 x 智能工厂:双核引擎驱动制造业数智未来

在当今数字化转型的浪潮中&#xff0c;智慧物流系统集成与智能工厂的紧密连接&#xff0c;正成为企业提升竞争力的重要途径。本文将探讨这两者如何通过智能制造解决方案与半导体生产线自动化的协同效应&#xff0c;共同推动生产效率的提升。随着行业需求的发展&#xff0c;通过…

作者头像 李华
网站建设 2026/4/11 7:29:59

printf函数在日志系统中的高级应用

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个简单的日志系统演示项目&#xff0c;展示printf函数的高级用法。功能包括&#xff1a;1) 使用printf输出带时间戳的日志&#xff1b;2) 实现日志级别控制&#xff08;DEBUG…

作者头像 李华
网站建设 2026/4/10 19:18:16

传统vs现代:AI如何将数据库错误修复时间缩短90%

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 设计一个效率对比工具&#xff0c;能够&#xff1a;1.模拟传统手动修复PostgreSQL错误的流程&#xff1b;2.展示AI辅助修复的流程&#xff1b;3.记录并比较两种方式的时间消耗&…

作者头像 李华
网站建设 2026/4/15 5:52:10

Qwen3-8B批量推理实战:Transformers pipeline应用

Qwen3-8B批量推理实战&#xff1a;Transformers pipeline应用 在当前大模型落地加速的背景下&#xff0c;如何在有限硬件资源下高效运行高性能语言模型&#xff0c;成为开发者面临的核心挑战之一。通义千问3系列中的 Qwen3-8B 模型&#xff0c;以80亿参数实现了接近更大规模模…

作者头像 李华