您的当前位置:首页正文

66 - vue3 - 新特性-defineOptions & defineModel

来源:华佗健康网

一.  Vue3.3 新特性-defineOptions

背景说明:
<script setup>之前,如果要定义 props,emits 可以轻而易举地添加一个与 setup 平级的属性

但是用了<script setup> 后,就没法这么干了 setup 属性已经没有了,自然无法添加与其平级的属性。

为了解决这一问题,引入了 defineProps defineEmits 这两个宏。但这只解决了 propsemits 这两个属性

如果我们要定义组件的 name 或其他自定义的属性,还是得回到最原始的用法一再添加一个普通的 script> 标签

这样就会存在两个 <script> 标签。让人无法接受

所以在 Vue 3.3 中新引入了 defineOptions 宏。顾名思义,主要是用来定义 Options API 的选项。可以用defineOptions 定义任意的选项,props,emits,expose, slots 除外 (因为这些可以使用 defineXXX 来做到)

<script setup>
defineOptions({
    name: 'Foo',
    inheritAttrs: false,
    // ...更多自定义属性
})
</script>

组件命名时可以使用

<script>
defineOptions({
    name:'LoginIndex'
})
</script>

<template>
    <div>wishing登录页</div>
</template>

二.  Vue3.3 新特性-defineModel

Vue3 中的 v-model 和 defineModel


在Vue3中,自定义组件上使用v-model,相当于传递一个modelValue属性,同时触发 update:modelvalue 事件

我们需要先定义 props,再定义emits 。其中有许多重复的代码。如果需要修改此值,还需要手动调用 emit 函数

使用defineModel

<script setup>
const modelValue = defineModel()
modelValue.value++
</script>
        1. vite.config.js 文件开启配置

2. 父子双向绑定

因篇幅问题不能全部显示,请点此查看更多更全内容