让自己的npm包拥有typescript类型支持

前言

别人使用我们发布的 npm 包时,可能不知道对应的参数,与对应的类型。

如何让我们的包拥有类型支持呢,使用 typescript 生成 d.ts 文件即可,我们来试试。

创建项目

$ mkdir project && cd project 
$ npm init -y

全局安装typescript

$ npm i typescript -g

使用typescript格式化项目

项目根目录执行。

$ npx tsc --init

会发现多出一个文件 tsconfig.json
在这里插入图片描述
我们修改对应的设置,添加设置"declaration": true,可以帮助我们编译 ts 文件自动额外生成 d.ts文件。

我这里还顺便加上了 "declarationMap": true,用于生成 d.ts.map 文件,你可以根据需要添加。

"declaration": true,       
"declarationMap": true, 

在这里插入图片描述
编写 index.ts 文件,我们要确保自己编写ts文件内容时严谨的控制自己的变量类型,这样自动生成的 d.ts 才有作用。

编译 ts

然后我们在项目根目录运行 tsc 开始编译。

$ tsc

会发现生成了对应的我们需要的 d.ts 文件
在这里插入图片描述

兼容性处理

要注意通过 ts 编译生成的 js 文件并没有做好兼容处理,我们上传npm包之前可能还需要对其进行es6到es5的兼容性处理。

详见另一篇文章:nodejs ES6模块使用 以及 ES6代码转ES5兼容性处理

推荐使用文章第二种方案,esbuild 相比 babel 比较简单且更快。

定义类型文件位置

记得在 package.json 中指明 d.ts 类型文件位置,否则该文件无法生效:

  "types": [
    "lib/index.d.ts"
  ],

在这里插入图片描述

尾言

做完以上步骤,就可以把我们的项目上传至npm仓库啦。

如果觉得文章对你有帮助的话,欢迎点赞收藏哦,有什么错误或者意见建议也可以留言,感谢~

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

在下月亮有何贵干

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

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

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

打赏作者

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

抵扣说明:

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

余额充值