当前位置: 首页 > article >正文

Vue3.3新特性defineModel

defineModel的使用:

defineModel选项可以帮我们省去很多麻烦

不仅需要上述操作,还需要进行一定的配置:

在vite.config.js中进行配置


defineModel是一个宏,所以不需要从vue中import导入,直接使用就可以了。这个宏可以用来声明一个双向绑定 prop,通过父组件的 v-model 来使用。

父组件:

<template>
  <CommonInput v-model="inputValue" />
</template>

<script setup lang="ts">
import { ref } from "vue";

const inputValue = ref();
</script>

子组件:

<template>
  <input v-model="model" />
</template>

<script setup lang="ts">
const model = defineModel();
model.value = "xxx";
</script>

在上面的例子中我们直接将defineModel的返回值使用v-model绑定到input输入框上面,无需定义 modelValue 属性和监听 update:modelValue 事件,代码更加简洁。defineModel的返回值是一个ref,我们可以在子组件中修改model变量的值,并且父组件中的inputValue变量的值也会同步更新,这样就可以实现双向绑定。

同一个变量不要进行多个双向绑定:

 使用arco组件的时候,自己封装的组件遇到的一个问题:

<a-tab-pane key="1" :title="`全部${total_1} `">
        <comment-table
          ref="comTable1"
          v-model:delete="deleteDialog1"
          v-model:audit="auditDialog1"
          v-model:total="total_1"
          v-model:search="searchTerm"
          itemType="1"
          @update:enabled="updateButtonState"
        ></comment-table>
      </a-tab-pane>
      <a-tab-pane key="2" :title="`待审${total_2}`">
        <comment-table
          ref="comTable2"
          v-model:delete="deleteDialog2"
          v-model:audit="auditDialog2"
          v-model:search="searchTerm"
          v-model:total="total_2"
          itemType="2"
          @update:enabled="updateButtonState"
        ></comment-table>
      </a-tab-pane>
      <a-tab-pane key="3" :title="`已批准${total_3}`">
        <comment-table
          ref="comTable3"
          v-model:delete="deleteDialog3"
          v-model:audit="auditDialog3"
          v-model:search="searchTerm"
          v-model:total="total_3"
          itemType="3"
          @update:enabled="updateButtonState"
        ></comment-table>
      </a-tab-pane>

 最开始的时候v-model三个自己封装的组件comment-table绑定的都是同一个属性,比如:

          v-model:delete="deleteDialog"
          v-model:audit="auditDialog"
          v-model:search="searchTerm"

复用三个就会出现问题,导致我对第二个子项操作的时候,莫名奇妙itemType就会从2变成3
最后修改成三个区分的变量就没问题了

原因:

v-model 是用于双向绑定的指令,通常用于将父组件的状态与子组件的内部状态进行同步。每个 v-model 都会绑定到一个特定的属性。这意味着在同一时间内,你不能将多个 v-model 指令绑定到同一个变量,因为这会导致数据冲突和不确定的行为。

  1. 数据冲突:

    • 如果多个 v-model 绑定到同一个变量,更新其中一个会导致其他绑定的变量也发生变化,从而产生不一致的状态。
  2. 双向绑定的复杂性:

    • 双向绑定的设计是为了让数据在父子组件之间保持同步。如果多个组件同时尝试更新同一个数据源,可能会导致难以预料的结果。
  3. 组件实例化:

    • 每个 comment-table 实例可能会有不同的状态和逻辑,试图将它们绑定到同一个变量会使得状态管理变得复杂和混乱。

http://www.kler.cn/a/321794.html

相关文章:

  • 网络原理-网络层和数据链路层
  • 基于Spring Boot的在线性格测试系统设计与实现(源码+定制+开发)智能性格测试与用户个性分析平台、在线心理测评系统的开发、性格测试与个性数据管理系统
  • 用枚举算法解决LeetCode第3348题最小可整除数位乘积II
  • 为什么海外服务器IP会被封
  • C语言打印时间精确到毫秒
  • 【C++】string类(附题)
  • 2023_Spark_实验十一:RDD基础算子操作
  • 从零开始使用树莓派debian系统使用opencv4.10.0进行人脸识别(保姆级教程)
  • Linux(Ubuntu)源码安装postgresql16.3
  • mysql数据库的基本管理
  • 【后端】【nginx】nginx常用命令
  • 力扣224. 基本计算器
  • 22 vue3之全局函数和变量插件编写
  • Flask中创建多线程和多进程
  • 黑龙江等保托管:全面解析与实践指南
  • IOS-IPA签名工具 request_post 任意文件读取复现
  • Stable Diffusion 使用详解(13)--- 3D纹理增强
  • C#邮件发送:实现自动化邮件通知完整指南!
  • 【Verilog学习日常】—牛客网刷题—Verilog企业真题—VL62
  • 软考高级:敏捷开发 SCRUM
  • 后端Java-SpringBoot整合MyBatisPlus步骤(超详细)
  • LabVIEW界面输入值设为默认值
  • 基于SSM+小程序的英语学习交流平台管理系统(学习3)(源码+sql脚本+视频导入教程+文档)
  • OpenHarmony(鸿蒙南向开发)——小型系统内核(LiteOS-A)【用户态内存调测】
  • RabbitMQ下载安装运行环境搭建
  • zTasker自动化任务的小工具