Node.js 将原生支持 TS!

Node.js 近日刚合并了一个 PR#53725,主要内容是通过设置 flag --experimental-strip-types,使得可以在 Node.js 中直接执行 TypeScript 文件Node.js 会自动将 TypeScript 源代码转译为 JavaScript 源代码,不需要手动安装依赖来做转译了 。在这个转译过程中,不会进行类型检查,所有的类型信息都会被丢弃

关于动机。在以往的所有调查中,用户都表达了这个需求,必须承认这一点不容忽视,用户有需求就要重视。同时,近年来 TypeScript 的普及率也是越来越高(现在不学 TS 感觉自己都要被淘汰了,哈哈哈...)。

通过 Node.js 内置 TS 功能,用户是不需要安装外部依赖和一些加载器的。

例如,直接运行 node index.ts

ts 复制代码
const foo: string = "foo";

转换后的代码为:

js 复制代码
const foo = "foo";

其他运行时环境也会将一些 TypeScript 特有的功能转化为 JavaScript,例如枚举(Enums),而枚举在 JavaScript 中是不存在的。至少在这个 PR 的初始阶段,不会进行这种转化,这意味着使用 Enum, namespaces 等特性将不可行。

在工具上选择 @swc/wasm-typescript,因为这考虑到了简洁性,其它工具可能会将 Rust 和 Go 也添加到工具链中,而 @swc/wasm-typescript 只是一个包含 wasm 文件和一个用于绑定 js 文件的小包,并且 Swc 目前也被 Deno 用于同样的目的,还经过了实战测试 😄。

目前还存在一些限制

  1. 不支持需要转化的 TypeScript 特性(如枚举、命名空间等)。
  2. .ts 文件不支持 .js 扩展名。
  3. 无法运行 node_modules 中的 TypeScript 文件。
  4. 不支持源映射,但由于我们执行空格处理(用空格替换移除的代码),这样就不需要改变原始错误堆栈,因此不需要源映射,参考 Sourcemaps 问题

该 PR 只是实现实验性支持 TS 的第一步,还有一些工作要做,详细参考实验性支持 TS 路线图

最后,关于 Node.js 将支持 TS 你怎么看?欢迎评论区留言!

相关推荐
小杨快跑~1 天前
Vue 3 + Element Plus 表单校验
前端·javascript·vue.js·elementui
我叫张小白。1 天前
Vue3监视系统全解析
前端·javascript·vue.js·前端框架·vue3
WYiQIU1 天前
11月面了7.8家前端岗,兄弟们12月我先躺为敬...
前端·vue.js·react.js·面试·前端框架·飞书
谢尔登1 天前
简单聊聊webpack摇树的原理
运维·前端·webpack
娃哈哈哈哈呀1 天前
formData 传参 如何传数组
前端·javascript·vue.js
zhu_zhu_xia1 天前
vue3+vite打包出现内存溢出问题
前端·vue
tsumikistep1 天前
【前后端】接口文档与导入
前端·后端·python·硬件架构
行走的陀螺仪1 天前
.vscode 文件夹配置详解
前端·ide·vscode·编辑器·开发实践
2503_928411561 天前
11.24 Vue-组件2
前端·javascript·vue.js
Bigger1 天前
🎨 用一次就爱上的图标定制体验:CustomIcons 实战
前端·react.js·icon