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

在Vue 3中,使用TypeScript时,如果想要通过defineExpose使得子组件暴露的方法具有类型提示,可以在父组件中定义一个接口来描述子组件暴露的属性和方法。

以下是一个简单的例子:

首先,定义子组件暴露的方法的接口:




// ChildComponent.ts
export interface ChildComponentExposedMethods {
  doSomething(): void;
  getValue(): number;
}

然后,在子组件中使用defineExpose来暴露方法:




<template>
  <!-- 子组件模板 -->
</template>
 
<script lang="ts">
import { defineComponent, ref } from 'vue';
import { ChildComponentExposedMethods } from './ChildComponent';
 
export default defineComponent({
  name: 'ChildComponent',
  setup() {
    const doSomething = () => {
      // 实现功能
    };
 
    const value = ref(0);
    const getValue = () => {
      return value.value;
    };
 
    // 暴露的方法
    const exposed = { doSomething, getValue } as ChildComponentExposedMethods;
 
    // 在Vue 3中使用defineExpose来暴露属性和方法
    defineExpose(exposed);
 
    return {};
  },
});
</script>

最后,在父组件中接收并使用这些方法时会有类型提示:




<template>
  <ChildComponent ref="childComp"/>
</template>
 
<script lang="ts">
import { defineComponent, ref } from 'vue';
import { ChildComponentExposedMethods } from './ChildComponent';
 
export default defineComponent({
  name: 'ParentComponent',
  setup() {
    const childComp = ref<Nullable<ChildComponentExposedMethods>>(null);
 
    const callChildMethod = () => {
      if (childComp.value) {
        childComp.value.doSomething();
        console.log(childComp.value.getValue());
      }
    };
 
    return {
      childComp,
      callChildMethod,
    };
  },
});
</script>

在父组件中,通过ref创建了一个childComp引用,并指定了它的类型为Nullable<ChildComponentExposedMethods>,这样在调用子组件暴露的方法时,就会有代码提示。

VUE
最后修改于:2024年08月17日 20:05

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日