Vue组件入门(八)v-model + 自定义参数

简介: Vue组件入门(八)v-model + 自定义参数

前言


在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 的双向绑定,完成数据的输入赋值更新。

相关文章
|
9天前
|
缓存 JavaScript UED
Vue 中实现组件的懒加载
【10月更文挑战第23天】组件的懒加载是 Vue 应用中提高性能的重要手段之一。通过合理运用动态导入、路由配置等方式,可以实现组件的按需加载,减少资源浪费,提高应用的响应速度和用户体验。在实际应用中,需要根据具体情况选择合适的懒加载方式,并结合性能优化的其他措施,以打造更高效、更优质的 Vue 应用。
|
13天前
|
JavaScript 前端开发 测试技术
组件化开发:创建可重用的Vue组件
【10月更文挑战第21天】组件化开发:创建可重用的Vue组件
22 1
|
14天前
|
JavaScript 前端开发 Java
《vue3第五章》新的组件,包含:Fragment、Teleport、Suspense
《vue3第五章》新的组件,包含:Fragment、Teleport、Suspense
25 2
|
JavaScript
Vue的非父子组件之间传值
全局事件总线 一种组件间通信的方式,适用于任意组件间通信
|
缓存 JavaScript 前端开发
Vue Props、Slot、v-once、非父子组件间的传值....
Vue Props、Slot、v-once、非父子组件间的传值....
83 0
|
JavaScript
Vue中父子组件传值
先在⽗组件中给⼦组件的⾃定义属性绑定⼀个⽗组件的变量
|
JavaScript
vue 组件传值
vue 组件传值
82 0
|
JavaScript
vue父子组件传值
vue父子组件传值
|
JavaScript
vue兄弟组件传值 方便快捷
vue兄弟组件传值 方便快捷
|
JavaScript
Vue父子组件传值(porvide+inject实现组件通信)
如果我们需要把父组件的值传递给子组件,而且子组件可能存在层层嵌套,那么就可以使用provide+inject的方法来实现组件之间的通信
191 0
Vue父子组件传值(porvide+inject实现组件通信)