令人兴奋的消息!Node.js 终于迎来了原生的 TypeScript 支持!
是的,现在你可以在 Node.js 中直接使用 TypeScript 类型了。
看来我可以把 typescript
和 ts-node
扔进垃圾桶了。
❌ 在此之前:
Node.js 只支持 JavaScript 文件。
像下面这样的代码根本无法运行:
尝试运行时,你会得到一个令人不悦的错误提示:
我们以前的最佳选择是安装 TypeScript 并使用 tsc
进行编译。
数百万开发者认为这已经是一个不错的选择:
但这很麻烦——每次都要安装相同的旧包,并反复输入相同的命令。
额外的编译步骤、处理 TypeScript 配置等问题都很令人沮丧,特别是当我们只是想做一些测试时。
正因如此,ts-node
出现了,试图解决这些问题——但它仍然不够完美。
我们可以直接运行 TypeScript 文件了:
甚至可以像使用 node
命令一样随时启动交互式会话:
每个人都很喜欢它:
但它仍然是一个额外的依赖项,而且我们仍然需要安装 TypeScript。
我们还必须注意一些更细微的复杂性,比如如何使用 ts-node
处理 ES 模块时的 --esm
标志。
✅ 现在:
随着 Node.js 的全新升级,这一切都改变了:
- 原生内置 TypeScript 支持。
- 无需依赖任何额外的包。
- 无需中间文件和模块配置。
现在,像 Prettier、Next.js 和 Webpack 这样的我们喜爱的 JS 工具可以拥有更安全和更具智能提示的配置文件。
好吧,几乎没有人会把 Webpack 列入他们最喜爱的工具列表,但不管怎样……
看看已经有类似的 Pull Request 来支持 Prettier 的 prettier.config.ts
了——这要归功于这一新发展,他们将迈出更大的步伐。
背后的工作原理是什么?
对 TypeScript 的支持将是渐进的,所以目前它只支持类型——你还不能使用像枚举这样的更典型的 TypeScript 特性(不过谁现在还用枚举呢)。
它使用 @swc/wasm-typescript
工具在内部去除 TypeScript 文件中的所有类型。
所以这段代码:
会被转换成这样:
如何在 Node.js 中开始使用 TypeScript
正如我之前提到的,这是一个早期的开始,所以它仍然是实验性的,目前你需要使用 --experimental-strip-types
标志:
node --experimental-strip-types index.ts
这将在即将发布的版本中得到支持。
最后的想法
内置 TypeScript 是一个重大的举措,使得 Node.js 成为 JavaScript 开发者更加愉快的平台。我肯定会使用这个功能。
尽管支持还不如 Bun 或 Deno 那样无缝,但它对整个 JavaScript 生态系统产生了深远的影响,因为 Node 仍然是目前最受欢迎的 JS 后端框架。
首发于公众号 大迁世界,欢迎关注。📝 每周一篇实用的前端文章 🛠️ 分享值得关注的开发工具 ❓ 有疑问?我来回答
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。