8

NodeJS的作者Ryan Dahl发布了一个新的运行时,旨在解决Node的许多缺点。你最初的反应可能是“哦,太棒了,另一个Javascript框架?正是我所需要的...”。别担心,我也有同样的反应。在了解了优势之后,我也看到了为什么Deno正是2020年后端Javascript开发人员所需要的。让我们来看看javascript开发人员使用Deno vs. Node获得更流畅,更现代的体验的5大原因。

1.现代Javascript——ES Modules

如果你是像我这样的React开发人员,你会注意到使用NodeJS导入软件包的语法是不同的。这是因为Node于2009年问世,此后对Javascript进行了大量更新和改进。

在React(和Deno)中,我们使用 import package from 'package' 语法导入包,而在Node中,我们使用const package = require("package") 语法。

ES Modules导入的优势在于两个原因:

  1. 使用 import,可以有选择地只从包中加载需要的部分,这节省了内存。
  2. 加载与 require 同步,而 import 则异步加载模块,从而提高了性能。

如果你在上图中注意到,我们正在从URL导入moment包,这将带给我们Deno的下一个优势。

2.去中心化的包

使用Deno,不再依赖NPM。是的,不再需要 package.json,每个包都是从URL加载的。

在NodeJS中,要使用软件包,必须首先从NPM安装它:

npm i moment

等待它安装,然后将其包含在你的应用程序中:

const moment = require("moment")

另外,任何时候有人要在本地运行你的NodeJS仓库时,都必须从NPM安装所有依赖项。

在Deno中,该包是从URL导入的,因此,如果要使用moment,只需导入https://deno.land/x/moment/mo...

关于Deno中软件包的另一个巨大优势是,安装后每个软件包都缓存在硬盘驱动器上。这意味着软件包的安装仅发生一次,如果要在任何地方再次导入依赖项,则不必下载它。

3.TypeScript是原生的,不需要配置

让TypeScript与NodeJS一起工作是一个多步骤的过程。你必须安装TypeScript,更新package.json,tsconfig.json,并确保你的模块支持@types。

在Deno中,你所要做的就是将文件另存为 .ts 而不是 .jsTypeScript编译器已经安装好了

4.顶层await——在异步函数之外使用await功能

在Node中,只能在异步函数中访问 await 关键字。

使用Deno,你可以随时随地 await 任何事情,而无需将其包装在异步函数中。

几乎所有Javascript应用程序都包含许多异步函数,这次升级使代码更加干净和简单。

5.访问浏览器API(Window,Fetch)

要使用javascript发出HTTP请求,我们可以使用Fetch API。在NodeJS中,我们没有访问Browser API的权限,因此我们不能直接调用获取函数。我们必须首先安装该软件包:

npm i node-fetch

然后导入包:

const fetch = require("node-fetch")

只有这样,我们才能进行调用。

Deno原生有权访问 window 对象,这意味着你可以继续调用fetch(“ https://something.com”)以及Browser API中的任何其他对象,而无需安装任何库。

结合顶层的await优势,你现在可以看到Deno代码比Node代码简单得多:

2020年以后编写Javascript代码的方式

并没有就此结束

Deno还有许多其他优点,例如默认情况下更安全,可以执行Wasm二进制文件,具有许多内置库,并且列表还在继续。

本文提到的所有要点都是相互联系的,共同形成一个更现代的2020年后端javascript运行时。作为一个React开发人员,我与Deno共鸣。现在,我可以使用导入语法,在任何需要的地方编写await,使用TypeScript而不进行任何配置,甚至可以调用fetch而无需安装软件包。很简单。

Deno最终会取代Node吗?也许。这可能需要几年时间。 NodeJS生态系统非常庞大,Deno可能需要一些时间才能赶上。但是Javascript开发人员最近一直喜欢Deno的新项目,因此,如果你打算尽快开始一个新项目,那么绝对值得研究。有关如何开始的更多信息,请访问deno.land


来源:https://levelup.gitconnected.com,作者:Dan Halperin,翻译:公众号《前端全栈开发者》

本文首发于公众号 《前端全栈开发者》 ID:by-zhangbing-dev,第一时间阅读最新文章,会优先两天发表新文章。关注后私信回复:大礼包,送某网精品视频课程网盘资料,准能为你节省不少钱!
subscribe2.png


杭州程序员张张
11.8k 声望6.7k 粉丝

Web/Flutter/独立开发者/铲屎官