持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第8天,点击查看活动详情
前言
在vue2中,一个组件上只能使用一个使用一个v-model,但是在vue3中,做了很大的改动,它允许你给v-mode 绑定参数,使用的传递的prop可以自定义。而这一绑定参数的改动,带给我一个好处,就是,可以在组件上使用多个v-model。而具体怎么做呢?我们来看一看。
v-model
的参数
回想一下,我们在组件绑定v-model的时候,他会转换成什么?
他会使用modelValue作为默认prop,使用update:modelValue作为对应的默认监听事件。
而我们想改变默认值的时候,就可以通过绑定参数来实现自定义。
<MyComponent v-model:name="name" />
这样的话,他就会转换成name 的prop以及update:name的事件。所以,在子组件中,我们只需要接受这个prop,和派发对应的事件就可以了。
<!-- MyComponent.vue -->
<script setup>
defineProps(['name'])
defineEmits(['update:name'])
</script>
<template>
<input
type="text"
:value="name"
@input="$emit('update:name', $event.target.value)"
/>
</template>
这样,我们就实现了一个自定义的v-model。
多个v-model
想必学会了绑定自定义参数,对于多个v-model绑定你也有自己的思路。下面我们来看看是怎么实现的。
父组件中:
<Book
v-model:author ="author"
v-model:price="price"
/>
子组件中:
<script setup>
defineProps({
author: String,
price: String
})
defineEmits(['update:author', 'update:price'])
</script>
<template>
<input
type="text"
:value="author"
@input="$emit('update:author', $event.target.value)"
/>
<input
type="text"
:value="price"
@input="$emit('update:price', $event.target.value)"
/>
</template>
这样我们就实现多个v-model的绑定,每一个自定义v-model绑定的参数都会生成对应的prop,而这声明的prop也会通过监听的事件的触发进行相应的更新。
也就是说我们完成了v-model 的双向绑定,完成数据的输入赋值更新。