您的位置:首页 > 新闻 > 会展 > 自媒体135app下载_网络营销方式和思路_怎么给网站做优化_网络营销推广主要做什么

自媒体135app下载_网络营销方式和思路_怎么给网站做优化_网络营销推广主要做什么

2025/2/27 5:48:59 来源:https://blog.csdn.net/2301_80826038/article/details/142351275  浏览:    关键词:自媒体135app下载_网络营销方式和思路_怎么给网站做优化_网络营销推广主要做什么
自媒体135app下载_网络营销方式和思路_怎么给网站做优化_网络营销推广主要做什么

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

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

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,然后在更新时,我们会将更新后的值传递给 emit 的 update: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 替代子组件中的 props 和 emit

<!-- 子组件 CustomComponent  -->
<template><input type="text" v-model="modelValue" />
</template><script setup>
const modelValue = defineModel();
</script>

带参数/定义多个 v-model

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

<!-- 父组件 -->
<template><div><!-- 自定义子组件 CustomComponent 使用 v-model 指令绑定 userName --><CustomComponentv-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>

修饰符和转换器

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

const [modelValue, modelModifiers] = defineModel()// 对应 v-model.trim
if (modelModifiers.trim) {// ...
}

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com