当前位置: 代码网 > it编程>编程语言>Javascript > Vue3.4中v-model双向数据绑定新玩法详解

Vue3.4中v-model双向数据绑定新玩法详解

2024年05月18日 Javascript 我要评论
前言随着 vue3.4 版本的发布,definemodel 也正式转正了。它可以简化父子组件之间的双向绑定,是目前官方推荐的双向绑定实现方式。之前在 vue3.3 中,该方法还是实验性方法,使用 de

前言

随着 vue3.4 版本的发布,definemodel 也正式转正了。它可以简化父子组件之间的双向绑定,是目前官方推荐的双向绑定实现方式。

之前在 vue3.3 中,该方法还是实验性方法,使用 definemodel 需在 vite.config.ts 里面配置 definemodeltrue,配置如下:

export default defineconfig({
  plugins: [
    vue({
      script: {
        definemodel: true,
      },
    }),
  ],
});

vue3.4 版本中已经是稳定特性了!!!

正式介绍 definemodel

definemodel 是一个新的 <script setup> 宏,旨在简化支持 v-model 的组件的实现, 这个宏用来声明一个双向绑定 prop,通过父组件的 v-model 来使用。

它之前作为实验性功能在 vue3.3 中发布,并在 vue3.4 中升级为稳定状态。现在,它还为 v-model修饰符的使用提供了更好的支持。

definemodel 使用

例举一个最简单的使用场景: 自定义组件中使用 v-model 来进行数据的双向绑定

<!-- 父组件 -->
<template>
  <div>
    <!-- 自定义子组件 customcomponent 使用 v-model 指令绑定 username -->
    <customcomponent v-model="username" />
  </div>
</template>

<script setup>
import { ref } from "vue";
import customcomponent from "./customcomponent.vue";

const username = ref("前端开发爱好者");
</script>

在 vue3.3 版本之前,我们通常通过 props 接收 modelvalue,然后在更新时,我们会将更新后的值传递给 emitupdate:modelvalue 并执行:

<!-- 子组件 customcomponent  -->
<template>
  <input
    :value="props.modelvalue"
    @input="emit('update:modelvalue', $event.target.value)"
  />
</template>

<script setup>
import { defineprops, defineemits } from "vue";

const props = defineprops(["modelvalue"]);

const emit = defineemits(["update:modelvalue"]);
</script>

vue3.4 版本之后,我们将使用 definemodel 替代子组件中的 propsemit

<!-- 子组件 customcomponent  -->
<template>
  <input type="text" v-model="modelvalue" />
</template>

<script setup>
const modelvalue = definemodel();
</script>

带参数/定义多个 v-model

组件中可以支持定义多个 definemodel,可以满足绑定多个双向绑定的属性

<!-- 父组件 -->
<template>
  <div>
    <!-- 自定义子组件 customcomponent 使用 v-model 指令绑定 username -->
    <customcomponent
      v-model="username"
      v-model:title="title"
      v-model:subtitle="subtitle"
    />
  </div>
</template>

<script setup>
import { ref } from "vue";
import customcomponent from "./customcomponent.vue";

const username = ref("前端开发爱好者");
const title = ref("前端开发爱好者_title");
const subtitle = ref("前端开发爱好者_subtitle");
</script>
<!-- 子组件 customcomponent  -->
<template>
  <input type="text" v-model="modelvalue" />
  <input type="text" v-model="title" />
  <input type="text" v-model="subtitle" />
</template>

<script setup>
const modelvalue = definemodel();
const title = definemodel("title");
const subtitle = definemodel("subtitle");
</script>

修饰符和转换器

为了获取 v-model 指令使用的修饰符,我们可以像这样解构 definemodel() 的返回值:

const [modelvalue, modelmodifiers] = definemodel()

// 对应 v-model.trim
if (modelmodifiers.trim) {
  // ...
}

当存在修饰符时,我们可能需要在读取或将其同步回父组件时对其值进行转换。我们可以通过使用 getset 转换器选项来实现这一点:

const [modelvalue, modelmodifiers] = definemodel({
  // get() 省略了,因为这里不需要它
  set(value) {
    // 如果使用了 .trim 修饰符,则返回裁剪过后的值
    if (modelmodifiers.trim) {
      return value.trim()
    }
    // 否则,原样返回
    return value
  }
})

参考连接:

结语

definemodel 的引入标志着 vue 在提升开发者体验方面迈出了重要的一步。现在,开发者可以更加专注于应用的逻辑和用户体验,而不是纠结于数据绑定的细节。让我们一起迎接 vue 3.4 带来的更多可能性吧!

以上就是vue3.4中v-model双向数据绑定新玩法详解的详细内容,更多关于vue v-model双向数据绑定的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com