Vue3的双向数据绑定

如果你有多个 ref 类型的数据需要在父子组件之间实现双向绑定,可以使用 v-model 来进行多个数据的双向绑定。在 Vue 3 中,v-model 默认是针对 modelValue 的,但你可以通过指定自定义的属性名来实现多个双向绑定。

多个 v-model 双向绑定的实现

在 Vue 3 中,你可以使用多个 v-model 绑定到不同的属性,利用 update:<propName> 事件来同步数据。下面是如何在父子组件之间实现多个 v-model 的双向绑定。

示例代码

父组件:多个 v-model 的双向绑定
vue 复制代码
<template>
  <div>
    <!-- 使用 v-model 实现多个双向绑定 -->
    <p>父组件值 1:{{ parentValue1 }}</p>
    <p>父组件值 2:{{ parentValue2 }}</p>

    <ChildComponent
      v-model:value1="parentValue1"
      v-model:value2="parentValue2"
    />
    
    <button @click="incrementParentValues">父组件增加值</button>
  </div>
</template>

<script setup>
import { ref } from 'vue';
import ChildComponent from './ChildComponent.vue';

// 父组件中的多个值
const parentValue1 = ref(0);
const parentValue2 = ref(0);

// 父组件的方法:更新多个值
function incrementParentValues() {
  parentValue1.value++;
  parentValue2.value++;
}
</script>
子组件:通过 v-model 和事件通信实现多个双向绑定
vue 复制代码
<template>
  <div>
    <!-- 子组件中显示父组件传递的多个值,并通过按钮修改它们 -->
    <p>子组件接收的值 1:{{ value1 }}</p>
    <p>子组件接收的值 2:{{ value2 }}</p>

    <button @click="incrementChildValues">子组件增加值</button>
  </div>
</template>

<script setup>
import { defineProps, defineEmits } from 'vue';

// 接收父组件传递的多个值
const props = defineProps({
  value1: {
    type: Number,
    required: true,
  },
  value2: {
    type: Number,
    required: true,
  },
});

// 子组件向父组件发送多个更新事件
const emit = defineEmits(['update:value1', 'update:value2']);

// 子组件方法:修改多个值并通知父组件
function incrementChildValues() {
  emit('update:value1', props.value1 + 1);
  emit('update:value2', props.value2 + 1);
}
</script>

工作原理

  1. 父组件的 v-model 绑定多个值

    • 在父组件中,通过 v-model:value1="parentValue1"v-model:value2="parentValue2" 分别将两个响应式的 ref 绑定到子组件的 value1value2
  2. 子组件的多个 modelValue

    • 在子组件中,使用 defineProps 来接收 value1value2,分别通过 props.value1props.value2 获取父组件传递的值。
  3. 子组件通过 emit 向父组件回传多个值

    • 当子组件修改某个值时,它通过 emit('update:value1', newValue)emit('update:value2', newValue) 向父组件回传新的值。
    • Vue 会自动更新父组件中的 parentValue1parentValue2
  4. 双向绑定

    • 父组件中的 parentValue1parentValue2 会根据子组件传回的值自动更新。
    • 子组件通过 v-model 获取到的 value1value2 会随着父组件值的变化而更新。

使用多个 v-model 时的注意事项

  • 自定义事件名称 :每个 v-model 都会对应一个 update:<propName> 的事件。如果你在子组件中使用多个 v-model,就需要为每个属性定义不同的 update:<propName> 事件(例如:update:value1, update:value2)。

  • 多个 v-model 的绑定 :Vue 3 支持通过多个 v-model 来绑定多个不同的属性,实现多重数据的双向绑定。

  • 响应式数据 :确保传递到子组件的 refreactive 数据是响应式的,只有这样父组件和子组件才能实现双向同步。

  • 组件清晰命名 :为了让代码更加易读,建议使用明确且符合语义的命名,比如 value1, value2,而不是使用同名的 modelValue


总结

使用多个 v-model 来实现多个属性的双向绑定是 Vue 3 中非常简便的做法。你可以根据需要传递多个响应式数据,并通过 update:<propName> 事件来更新这些数据。这种方式既简洁又灵活,能够很好地适应父子组件之间复杂的数据交互。

相关推荐
90后的晨仔几秒前
Vue3项目全面部署指南:从构建到上线
前端·vue.js
小于小于09129 分钟前
npx 与 npm 区别
前端·npm·node.js
重生之我要当java大帝12 分钟前
java微服务-尚医通-数据字典-5
vue.js·微服务·云原生·架构
望获linux27 分钟前
【实时Linux实战系列】实时 Linux 在边缘计算网关中的应用
java·linux·服务器·前端·数据库·操作系统
qq_2529241928 分钟前
PHP 8.0+ 现代Web开发实战指南 引
android·前端·php
Jeled28 分钟前
Android 本地存储方案深度解析:SharedPreferences、DataStore、MMKV 全面对比
android·前端·缓存·kotlin·android studio·android jetpack
Mintopia29 分钟前
🎨 AIGC 内容过滤技术:当创作的洪流遇上理性的堤坝
前端·javascript·aigc
Mintopia36 分钟前
⚙️ Next.js 缓存与队列:当数据与请求跳起“低延迟之舞”
前端·全栈·next.js
Shi_haoliu44 分钟前
Vue2 + Office Add-in关于用vue项目于加载项控制excel单元格内容(Demo版)
前端·javascript·vue.js·node.js·html·excel·office
计算机毕业设计木哥1 小时前
计算机毕业设计选题推荐:基于SpringBoot和Vue的爱心公益网站
java·开发语言·vue.js·spring boot·后端·课程设计