news 2026/6/23 21:14:41

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/23 18:36:32

YOLO目标检测入门:手把手教你跑通第一个demo

YOLO目标检测入门&#xff1a;手把手教你跑通第一个demo 在智能制造车间的流水线上&#xff0c;摄像头正实时捕捉每一个经过的产品。突然&#xff0c;系统发出警报——一件外壳有细微裂纹的设备被准确识别并剔除。整个过程耗时不到30毫秒。这背后&#xff0c;很可能就是YOLO在默…

作者头像 李华
网站建设 2026/6/23 18:55:24

1小时搭建:VSCode远程开发环境原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个VSCode远程开发环境快速搭建工具&#xff0c;能够在1小时内完成&#xff1a;1) 基础环境检测 2) 必要插件自动安装 3) 最小化SSH配置 4) 连接测试 5) 示例项目部署。要求工…

作者头像 李华
网站建设 2026/6/23 2:47:37

电商项目实战:Vue3父子组件传值最佳实践

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个电商商品筛选组件示例。父组件包含商品列表和筛选条件状态&#xff0c;子组件是筛选侧边栏。要求实现&#xff1a;1)父组件向子组件传递商品分类数据 2)子组件通过事件发射…

作者头像 李华
网站建设 2026/6/22 21:57:52

备赛三--

1.then()在 JavaScript 中&#xff0c; then() 是Promise 对象的核心方法&#xff0c;用于指定异步操作成功后的回调函数&#xff0c;也是 fetch 、Promise 链式调用的关键&#xff0c;常和 catch() 、 finally() 配合处理异步流程。一、 then() 基本语法javascript pr…

作者头像 李华