Deno 内部代码将停用 TypeScript,并公布五项具体理由

2020 年 6 月 23 日 InfoQ
作者 | Elio Rivero
译者 | 核子可乐
策划 | 蔡芳芳

日前 Deno 官方公布的一份文档指出,出于对当前环境的实际考虑,Deno 将停止在内部代码中继续使用 TypeScript。文档中提到的问题涉及 TypeScript 编译时间、结构以及代码组织方式等。未来,Deno 项目将使用纯 JavaScript 编写内部代码。

TypeScript 给 Deno 带来的问题

在使用 TypeScript 编写内部代码时,Deno 团队遇到了以下几个现实问题:

在变更文件时,TypeScript 往往需要几分钟的编译时间,这就导致连续编译过程变得非常缓慢;

在创建 Deno 可执行文件以及面向用户的 API 源文件时,TypeScript 结构会引发一系列运行时性能问题;

TypeScript 本身对于 Deno 代码的组织工作毫无帮助,反而增强了代码组织负担。Deno 团队提出的一大现实问题,是 TypeScript 会在两个位置复制相互独立的 Body 类;

由于 TypeScript 编译器无法帮助开发者生成 d.ts 文件,内部代码与运行时 TypeScript 声明必须以手动方式保持同步;

他们维护着两台 TS 编译器主机:一台用于内部 Deno 代码,另一台用于外部用户代码,但二者的作用其实非常相似。

在内部 Deno 代码中移除 TypeScript

Deno 团队计划删除内部 Deno 代码中的所有构建时 TS 类型检查与捆绑。团队打算将所有运行时代码转移到同一个 JavaScript 文件当中,但仍将使用随附的 d.ts 文件保存类型定义与说明文档。

值得一提的是,Deno 将仅在内部 Deno 代码中停用 TypeScript:Deno 用户代码中的 TypeScript 部分仍将保留,类型检查自然也将一同存在。

虽然 TypeScript 常被视为 JavaScript 的改进版本,但此次情况提醒我们问题也许没那么简单。与任何其他语言一样,TypeScript 也有自己的缺陷。其最重要的问题之一,在于缓慢的编译速度。 在从纯 JavaScript 转换至 TypeScript 时,小型项目可能编译变慢的问题还不算严重,但大型项目(例如复杂的 React 应用程序)则将深受其害。从 Deno 项目的体量出发,停止使用 TypeScript 也算是顺理成章。

但这种性能妥协也可以理解,毕竟在开发过程中进行类型检查,相当于用编译时长换取安全保障。当然,TypeScript 项目中也提供关于如何解决并缩短编译时间的大量说明文档。最有趣的方法之一当数项目引用,意味着开发人员可以将大规模 TypeScript 代码片段拆分为较小的代码片段。

关注 Deno 停止使用 TypeScript 的更多详细信息

感兴趣的朋友可以点击此处,了解 Deno 项目团队在移除 TypeScript 并转而使用 JavaScript 方面的完整讨论。Ryan Dahl 及其合作者在其中全面探讨了当前问题、解决方案以及实现途径。

参考阅读:

https://startfunction.com/deno-will-stop-using-typescript/



InfoQ 读者交流群上线啦!各位小伙伴可以扫描下方二维码,添加 InfoQ 小助手,回复关键字“进群”申请入群。大家可以和 InfoQ 读者一起畅所欲言,和编辑们零距离接触,超值的技术礼包等你领取,还有超值活动等你参加,快来加入我们吧!




点个在看少个 bug 👇

登录查看更多
0

相关内容

TypeScript is a language for application-scale JavaScript development.TypeScript is a typed superset of JavaScript that compiles to plain JavaScript. typescriptlang.org/
【2020新书】C++20快速语法参考,第4版,209页pdf
专知会员服务
74+阅读 · 2020年8月5日
【经典书】Python金融大数据分析,566页pdf
专知会员服务
124+阅读 · 2020年8月1日
【高能所】如何做好⼀份学术报告& 简单介绍LaTeX 的使用
Transformer文本分类代码
专知会员服务
117+阅读 · 2020年2月3日
2019年机器学习框架回顾
专知会员服务
36+阅读 · 2019年10月11日
用 GitLab 的 Merge Request 做代码评审
DevOps时代
4+阅读 · 2019年5月5日
我的if else代码纯净无暇,一个字也不能简化
机器之心
3+阅读 · 2018年12月28日
Python3.7中一种懒加载的方式
Python程序员
3+阅读 · 2018年4月27日
号称“开发者神器”的GitHub,到底该怎么用?
算法与数据结构
4+阅读 · 2018年3月29日
教你用Python进行自然语言处理(附代码)
数据派THU
6+阅读 · 2018年3月28日
为什么你应该学 Python ?
计算机与网络安全
4+阅读 · 2018年3月24日
15000个开源项目中挑选Top 12,第一就是……
七月在线实验室
8+阅读 · 2018年1月17日
Arxiv
13+阅读 · 2019年4月9日
Arxiv
3+阅读 · 2018年12月19日
CoQA: A Conversational Question Answering Challenge
Arxiv
7+阅读 · 2018年8月21日
Arxiv
8+阅读 · 2018年4月8日
Arxiv
5+阅读 · 2018年1月30日
VIP会员
相关VIP内容
【2020新书】C++20快速语法参考,第4版,209页pdf
专知会员服务
74+阅读 · 2020年8月5日
【经典书】Python金融大数据分析,566页pdf
专知会员服务
124+阅读 · 2020年8月1日
【高能所】如何做好⼀份学术报告& 简单介绍LaTeX 的使用
Transformer文本分类代码
专知会员服务
117+阅读 · 2020年2月3日
2019年机器学习框架回顾
专知会员服务
36+阅读 · 2019年10月11日
相关资讯
用 GitLab 的 Merge Request 做代码评审
DevOps时代
4+阅读 · 2019年5月5日
我的if else代码纯净无暇,一个字也不能简化
机器之心
3+阅读 · 2018年12月28日
Python3.7中一种懒加载的方式
Python程序员
3+阅读 · 2018年4月27日
号称“开发者神器”的GitHub,到底该怎么用?
算法与数据结构
4+阅读 · 2018年3月29日
教你用Python进行自然语言处理(附代码)
数据派THU
6+阅读 · 2018年3月28日
为什么你应该学 Python ?
计算机与网络安全
4+阅读 · 2018年3月24日
15000个开源项目中挑选Top 12,第一就是……
七月在线实验室
8+阅读 · 2018年1月17日
相关论文
Top
微信扫码咨询专知VIP会员