【vue高频面试题】第7题:Vue3 中 `v-model` 的工作原理是什么?为什么 Vue3 支持多个 v-model?如何在子组件中实现?

Vue3 高频题 · 第 7 题

主问题

问:Vue3 中 v-model 的工作原理是什么?为什么 Vue3 支持多个 v-model?如何在子组件中实现?


一、核心回答(面试官满意版)

1)Vue3 的 v-model 实际上是 props + emit 的语法糖

在父组件中:

ini 复制代码
<Child v-model="username" />

等价于:

ini 复制代码
<Child 
  :modelValue="username" 
  @update:modelValue="val => username = val" 
/>

也就是说:

  • props:modelValue
  • emit:update:modelValue

Vue3 统一了 v-model 的名字,让逻辑更一致、更可扩展。


2)支持多个 v-model(Vue2 不支持)

Vue2 只有固定的一个 value 和事件 input

Vue3 允许:

ini 复制代码
<Child 
  v-model:title="title" 
  v-model:content="content" 
/>

等价于:

ini 复制代码
<Child
  :title="title"
  @update:title="val => title = val"

  :content="content"
  @update:content="val => content = val"
/>

二、在子组件中如何实现?(最重要)

子组件写法(script setup)

xml 复制代码
<script setup>
const props = defineProps({
  modelValue: String,
  title: String,
  content: String
})

const emit = defineEmits([
  'update:modelValue',
  'update:title',
  'update:content'
])

function changeValue(e) {
  emit('update:modelValue', e.target.value)
}
</script>

<template>
  <input :value="modelValue" @input="changeValue" />
</template>

三、Vue3 v-model 的功能增强(面试官喜欢听)

① v-model 可以做双向绑定(依旧保持 Vue2 的能力)

② v-model 不再绑定固定的 value / input

可以绑定任何属性名,如:

ini 复制代码
v-model:checked="isChecked"
v-model:current-page="page"

③ 修饰符也可以自定义(Vue3 的新特性)

ini 复制代码
<Child v-model.trim="value" />

子组件可接受:

javascript 复制代码
defineProps({
  modelValue: String,
  modelModifiers: Object
})

四、典型示例:自定义 Input 组件

父组件

ini 复制代码
<CustomInput v-model="msg" />

子组件

xml 复制代码
<script setup>
const props = defineProps(['modelValue'])
const emit = defineEmits(['update:modelValue'])

function onInput(e) {
  emit('update:modelValue', e.target.value)
}
</script>

<template>
  <input :value="modelValue" @input="onInput">
</template>

五、深度追问(面试官常考)


追问 1:v-model 在 template 中为什么不需要写 .value

因为 Vue 会自动ref 解包(unwrap)

模板中自动把 ref.value 转成普通值展示。


追问 2:v-model 为什么要用事件 update:modelValue 而不是 input?

为了避免名称冲突,并且可以支持多个 v-model。

如果使用 input/value 就不可能做多字段绑定。


追问 3:可以把 v-model 的属性名改成别的吗?

可以!

例如:

ini 复制代码
<Child v-model:visible="showDialog" />

子组件 props:

css 复制代码
defineProps(['visible'])
defineEmits(['update:visible'])

追问 4:多个 v-model 会影响性能吗?

不会。

它只是更多的 props 与 emit,没有额外开销。


六、killer 问题(高分必杀)

❓ "v-model 的原理和 provide/inject 有什么关系?"

答:没有关系!

v-model 只是父子之间最常用的"单属性双向绑定",

provide/inject 是跨层级通信,两者的作用和原理完全不同。

能回答清楚这一点,说明你能区分 Vue3 的通信场景 → 加分。


七、最终总结(1 分钟背诵版)

Vue3 的 v-model = modelValue + update:modelValue 的语法糖。

Vue3 可以绑定多个 v-model,因为事件名可动态命名。

子组件必须:

  1. 定义对应 props
  2. 定义对应 emit
  3. 事件里 emit 回去

v-model 的核心价值是规范、统一、支持多字段绑定,自定义组件必考点。

相关推荐
luguocaoyuan44 分钟前
前端沙箱隔离技术详解:从原理到实践
前端
前端一课1 小时前
【vue高频面试题】第3题:Vue 3 中的 computed 是什么?和 watch 有什么区别?什么时候用哪一个?
前端·面试
Json____1 小时前
vue2-数码购物商城-前端静态网站
前端·vue·数码商城
@大迁世界1 小时前
03.CSS嵌套 (Nesting)
前端·css
DevUI团队1 小时前
解锁前端高阶调试:浏览器/IDE/Git技巧分享
前端·javascript·html
前端一课1 小时前
【vue高频面试题】第一题:Vue 3 相比 Vue 2,有哪些重大变化?
前端·面试
前端一课1 小时前
【vue高频面试题】第2题:Vue 3 中 ref 和 reactive 的区别是什么?什么时候用哪一个?
前端·面试
用户8168694747251 小时前
React 事件系实现
前端·react.js
一颗烂土豆1 小时前
🚀从 autofit 到 vfit:Vue 开发者该选哪个大屏适配工具?
前端·vue.js