vue3.4中的v-model的用法~

1.首先以前我们针对父子组件传参是不是通过definePropsdefineEmits来实现的,但是这么 比较繁琐,因为他是单向传参,而不是双向的,这里我们要介绍的是vue3.4的v-model来实现双向数据传递。

2、代码示例:

javascript 复制代码
//父组件
<template>
    <Add ref="addForm" v-model="drawerStates.add"></Add>
</template>

import Add from './add.vue'
const addForm = ref(null)
const drawerStates = reactive({
  add: false
})

//子组件
//父组件使用 v-model="state" 时,这个 state 值会传递给 modelValue prop
const props = defineProps({
  modelValue: Boolean//这是 Vue 3 中 v-model 的默认 prop 名称
})
// 定义组件可以触发的事件
// 当子组件触发这个事件时,父组件的 v-model 值会更新
const emit = defineEmits(['update:modelValue'])
// 创建一个计算属性 drawerOpen,用于双向绑定
const drawerOpen = computed({
    //  从父组件获取当前值
  get() {
    return props.modelValue
  },
    // 通知父组件值的变化
  set(value) {
    emit('update:modelValue', value)
  }
})
//这样在子组件内部可以像使用普通 ref 一样使用 drawerOpen.value

3、工作流程:

  1. 当父组件 drawerStates.add 变化 → 自动更新 props.modelValue

  2. 当子组件修改 drawerOpen.value → 触发 update:modelValue → 父组件 drawerStates.add更新

4、为什么这么写?

  1. 实现真正的双向绑定,而不仅仅是单向数据流

  2. 保持组件状态与父组件同步

  3. 符合 Vue 3 的组件通信规范

  4. 使组件可以像原生表单元素一样工作

相关推荐
伍哥的传说39 分钟前
React & Immer 不可变数据结构的处理
前端·数据结构·react.js·proxy·immutable·immer·redux reducers
90后的晨仔1 小时前
从传统 CSS 到 Vue 的 Class 与 Style 动态绑定全解
前端·vue.js
拾光拾趣录1 小时前
前端灵魂拷问:10道题
前端·面试
阿丽塔~2 小时前
【vue3+vue-pdf-embed】实现PDF+图片预览
javascript·vue.js·pdf
独泪了无痕2 小时前
Vite 模块动态导入之Glob导入
前端·vue.js·vite
xdpcxq10292 小时前
Docker用Web应用实例深入容器
前端·docker·容器
超浪的晨3 小时前
JavaWeb 入门:JavaScript 基础与实战详解(Java 开发者视角)
java·开发语言·前端·javascript·后端·学习·个人开发
tianchang3 小时前
React Hook 解析(二):`useEffect` 与 `useLayoutEffect`
前端·react.js
codervibe3 小时前
使用 Vue3 + Axios 与 Spring Boot 高效对接(含 token 处理)
前端·vue.js
云边散步3 小时前
《校园生活平台从 0 到 1 的搭建》第五篇:商品后端
前端·后端