0


vue3 ts 如何让子组件通过 defineExpose 暴露的方法有代码提示

有时,你可能需要为一个子组件添加一个模板引用,以便调用它公开的方法。举例来说,我们有一个 Child 子组件,它有一个打开模态框的方法:

<!-- MyModal.vue -->
<script setup lang="ts">
import { ref } from 'vue'

const isContentShown = ref(false)
const open = () => (isContentShown.value = true)

defineExpose({
  open
})
</script>

为了获取

MyModal

的类型,我们首先需要通过

typeof

得到其类型,再使用 TypeScript 内置的

InstanceType

工具类型来获取其实例类型:

<!-- App.vue -->
<script setup lang="ts">
import MyModal from './MyModal.vue'

const modal = ref<InstanceType<typeof MyModal> | null>(null)

const openModal = () => {
  modal.value?.open()
}
</script>

官网跳转 Vue官方文档


本文转载自: https://blog.csdn.net/Jeason_KK/article/details/128914220
版权归原作者 不会飞的飞行员_ 所有, 如有侵权,请联系我们删除。

“vue3 ts 如何让子组件通过 defineExpose 暴露的方法有代码提示”的评论:

还没有评论