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. 父子双向绑定

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值