Deno将停止使用TypeScript,并公布五项具体理由
Posted 前端之巅
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Deno将停止使用TypeScript,并公布五项具体理由相关的知识,希望对你有一定的参考价值。
在使用 TypeScript 编写内部代码时,Deno 团队遇到了以下几个现实问题:
在变更文件时,TypeScript 往往需要几分钟的编译时间,这就导致连续编译过程变得非常缓慢;
在创建 Deno 可执行文件以及面向用户的 API 源文件时,TypeScript 结构会引发一系列运行时性能问题;
TypeScript 本身对于 Deno 代码的组织工作毫无帮助,反而增强了代码组织负担。Deno 团队提出的一大现实问题,是 TypeScript 会在两个位置复制相互独立的 Body 类;
https://github.com/denoland/deno/issues/4748
由于 TypeScript 编译器无法帮助开发者生成 d.ts 文件,内部代码与运行时 TypeScript 声明必须以手动方式保持同步;
他们维护着两台 TS 编译器主机:一台用于内部 Deno 代码,另一台用于外部用户代码,但二者的作用其实非常相似。
Deno 团队计划删除内部 Deno 代码中的所有构建时 TS 类型检查与捆绑。团队打算将所有运行时代码转移到同一个 JavaScript 文件当中,但仍将使用随附的 d.ts 文件保存类型定义与说明文档。
值得一提的是,Deno 将仅在内部 Deno 代码中停用 TypeScript:Deno 用户代码中的 TypeScript 部分仍将保留,类型检查自然也将一同存在。
虽然 TypeScript 常被视为 JavaScript 的改进版本,但此次情况提醒我们问题也许没那么简单。与任何其他语言一样,TypeScript 也有自己的缺陷。其最重要的问题之一,在于缓慢的编译速度。 在从纯 JavaScript 转换至 TypeScript 时,小型项目可能编译变慢的问题还不算严重,但大型项目(例如复杂的 React 应用程序)则将深受其害。从 Deno 项目的体量出发,停止使用 TypeScript 也算是顺理成章。
但这种性能妥协也可以理解,毕竟在开发过程中进行类型检查,相当于用编译时长换取安全保障。当然,TypeScript 项目中也提供关于如何解决并缩短编译时间的大量说明文档。最有趣的方法之一当数项目引用,意味着开发人员可以将大规模 TypeScript 代码片段拆分为较小的代码片段。
感兴趣的朋友可以移步 Google 发布的文档,了解 Deno 项目团队在移除 TypeScript 并转而使用 JavaScript 方面的完整讨论。
https://docs.google.com/document/d/1_WvwHl7BXUPmoiSeD8G83JmS8ypsTPqed4Btkqkn_-4/preview?pru=AAABcrrKL5k*nQ4LS569NsRRAce2BVanXw
Ryan Dahl 及其合作者在其中全面探讨了当前问题、解决方案以及实现途径。
https://startfunction.com/deno-will-stop-using-typescript/
GMTC 全球大前端技术大会(北京站)2020 关注前端、移动、AI 应用等多个技术领域,大会聚焦前沿技术及实践经验,旨在帮助参会者了解大前端 & 移动开发领域的技术趋势与实践案例。大会目前 8 折优惠报名,限时立减 960 元!了解更多大会内容,可扫描下图二维码或点击【阅读原文】。联系票务经理鱼丸:13269078023(同微信)
以上是关于Deno将停止使用TypeScript,并公布五项具体理由的主要内容,如果未能解决你的问题,请参考以下文章
Deno 1.6正式发布!支持将TypeScript编译成单个可执行文件,苹果M1可原生运行
如何将定义 typescript 文件类型文件链接到 deno 的另一个定义类型文件中?