Vue3 组件二次封装 添加-类型声明

通过在`types/components.d.ts`中声明组件类型,可以为Vue组件添加类型提示,如`Vant`的`NavBar`。使用`typeof`获取组件实例类型,然后在`declaremodulevue`里定义全局组件接口,如`CpNavBar:typeofCpNavBar`。这样,在使用封装的组件时,编辑器能提供属性和事件的提示。
摘要由CSDN通过智能技术生成
解释:给组件添加类型,让写属性和事件可以有提示

提问:

  • vant 的组件为啥有提示?

  • 可以使用键盘ctrl+鼠标左键 查看 vant 的组件类型声明文件

发现:

// 核心代码
// 1. 导入组件实例
import NavBar from './NavBar.vue'
// 2. 声明 vue 类型模块
declare module 'vue' {
    // 3. 给 vue  添加全局组件类型,interface 和之前的合并
    interface GlobalComponents {
        // 4. 定义具体组件类型,typeof 获取到组件实例类型
        // typeof 作用是得到对应的TS类型
        VanNavBar: typeof NavBar;
    }
}

给自己封装的 组件添加类型:

types/components.d.ts

// 引入我们的组件
import CpNavBar from '@/components/CpNavBar.vue'

declare module 'vue' {
  interface GlobalComponents {
    // 使用 typeof 拿到组件的类型,给到封装的组件
    CpNavBar: typeof CpNavBar
  }
}

对vant组件进行二次封装

使用我们封装的组件时,也会有提示,没有传title属性也会有提示

验证

  1. 看看属性提示,事件提示,鼠标放上去有没有类型。

  1. 代码提示不需要组件双闭合,单标签页可以

小结:

  • 怎么给全局的组件提供类型?

  • 写一个类型声明文件,declare module 'vue' 声明一个 vue 类型模块

  • 然后 interface GlobalComponents 书写全局组件的类型

  • key组件名称支持大驼峰,value是组件类型,通过 typeof 组件实例得到

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不叫虎子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值