比较node.js和Deno


Posted in Javascript onApril 27, 2021

前言

如果你一直关注 Web 开发领域,那么最近可能已经听到了很多关于 Deno 的信息——一种新的JavaScript运行时,它可能也会被认为是 Node.js的继承者。但是这意味着什么,我们需要“下一个 Node.js” 吗?

什么是 Deno?

要了解发生了什么,我们首先需要看一下 Deno 到底是什么。就像我前面说过的那样,这是一个新的JavaScript运行时,也就是要执行 JS代码的环境。它最初是由Ryan Dahl创造的,他在之前曾经为我们把 Deno 与Node.js进行了比较。

Ryan在JSConf EU 2018 演讲上宣布了 Deno,标题为“Node.js 的十大遗憾”。仅从那条信息中,你就可以知道进展情况。 Deno 是从头开始创建的,是当前对 Node.js 的更好的实现。

但是 Node.js 有什么不好的地方?Deno 如何与它更成熟的表兄抗衡?

与 Node.js 的比较

尽管 Deno 和 Node.js 是执行相似操作的类似工具,但它们之间的差异远远不只是名称的颠倒。

体系结构

让我们先来了解一下 Deno 的内部原理。就像 Node.js 一样,它基于 Chromium 的V8JavaScript 引擎,并使用事件驱动,非阻塞架构。但是两者的主要编写语言有所不同。Node.js 主要使用C ++编写,libuv作为其异步 I/O 库,而 Deno 用的是Rust,同样其使用的异步库Tokio也是用 Rust 编写。

对于这些差异如何转化为实际性能,我们必须拭目以待。就目前而言,根据Deno 的基准,两者之间的区别是无法区分的,或者说至少是非常微妙的。

ES模块

你可能知道,Node.js 当前的模块系统是所谓的CommonJS(带有require()的那个),尽管ESM( ECMAScript 模块(带有import和export的模块)成为 JS 的官方标准已有相当长的一段时间了,可以追溯到2015 年推出的ES6。当然,Node.js 确实支持 ESM,但是此功能目前([ v14.xx) 被标记为实验性的,从而迫使 JS 社区仍然使用 CommonJS 模块系统 或其他打包器。

这就是 Deno 要推出的东西,它仅支持 ESM 模块 —— 一个真正的模块系统!

依赖管理

但是,除了 ESM 之外,Deno 还为 Node.js 带来的依赖性管理带来了更多变化。

基于从有着上百万个包的npmregistry和类似黑洞的node_modules目录中汲取的经验,Deno 采用了一种完全不同的依赖关系方法。 Deno 不需要类似npm的 registry 和包管理器,而是直接从 URL 导入并使用依赖项:

import { serve } from "https://deno.land/std@0.50.0/http/server.ts";
const s = serve({ port: 8000 });
console.log("http://localhost:8000/");
for await (const req of s) {
    req.respond({ body: "Hello World\n" });
}

然后将下载的模块不可见地存储在计算机上的某个位置。是的,这意味着不会再有node_modules!

可是等等!还有更多...或者我应该少说,因为 Deno 还摆脱了现在制作的万能的package.json文件。除了deps.ts文件之外没有其他的替代选择,它的作用更像是所有外部模块的重定向排序文件:

export { assert } from "https://deno.land/std@v0.39.0/testing/asserts.ts";
export { green, bold } from "https://deno.land/std@v0.39.0/fmt/colors.ts";

至于 NPM registry,因为 Deno 现在可以从 URL 加载依赖项,所以这与 Node.js 的要求不一样。但是如果你对这个选项感兴趣,Deno 会提供自己的包托管。

TypeScript 和其他功能

是的,你已经看到了 ——JavaScript 是使用 Deno 的主要语言,另外还支持TypeScript,。该支持是内置的,不需要类似custom registers的东西或复杂的设置。

但是,除了 TS 支持之外,Deno 还内置了许多其他有用的工具。它们当中的大多数以命令形式出现,例如fmt、bundle或doc,分别提供代码格式化,打包和文档生成等功能。

API

至于 API,Deno 肯定是自己的东西。一切都是用 TypeScript 编写的,异步 API 仅基于Promise。核心功能被限制在最低限度,而其他所有功能都可以在标准库中找到。

所以从表面上看,这一切看起来都很好,而且非常有前途,但是当你意识到更改所有的 API 意味着将 Node.js 代码库转换为 Deno 更加困难时,这种愉悦的心情立即消失了。可悲的是,所有新的和更好的东西都必须付出代价,对吗?

安全

最后,安全性是 Deno 最重要的方面之一。与 Node.js 相比,它用沙盒执行的代码,仅允许访问系统的选定部分。这意味着通过传递适当的标志,可以轻松地限制对磁盘、网络和子进程等内容的访问。

那么,这意味着什么?

因此,我刚刚以非常简短的方式向你介绍了 Deno 的一些功能,以便你能够掌握所有内容的要点。你可以根据需要进行更深入的研究(我将在本文结尾放一些不错的文章链接)。

让我们回过头来讨论这个博客文章的主要问题——这意味着什么?好吧,主要是因为Deno v1已经在2020 年 5 月 13 日发布(正好是其首次发布的第二年)。现在每个人都在问这是否将会成为“下一个大事件”,或者它是否将会完全取代 Node.js。

就个人而言,我认为现在讨论这些还为时过早。考虑到项目的规模和社区的期望,该项目尽管已经是 v1 版了,但要成为可行的 Node.js 替代者还有很长的路要走。请记住,这些技术(即使存在所有差异)仍然要做同样的事情,同时必须相互竞争。而且 Node.js 的开发也不会过时(例如基于 Promise 的 FS API变体或 ESM 实验性支持),这意味着我们很可能会在这个存在两个 JavaScript 运行时的世界中生活很长时间(说的好像对 JS 开发人员来说是个新鲜事一样)。并且请记住,我甚至没有提到庞大的 NPM registry 和生态系统,尽管它们无论如何都不是完美的,但仍然为 Node.js 增添了很多价值——这是 Deno 目前还不具备的优势。

底线

总而言之,Node.js 不会出现在任何地方,并且,如果你要启动一个用于生产的严肃项目,那么至少就目前而言,最好还是坚持使用 Node.js。话虽如此,但是没有什么人(当然不是我)或事情能够阻止你去使用 Deno,甚至把 Deno 用于严肃的项目。看起来它确实像是未来,但是我们根本还没有到达。

以上就是比较node.js和Deno的详细内容,更多关于node.js和Deno的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
一些易混淆且不常用的属性,希望有用
Jan 29 Javascript
jQuery prototype冲突的2种解决方法(附demo示例下载)
Jan 21 Javascript
JS模拟的Map类实现方法
Jun 17 Javascript
用Vue.js实现监听属性的变化
Nov 17 Javascript
AngularJS自定义服务与fliter的混合使用
Nov 24 Javascript
angular十大常见问题
Mar 07 Javascript
基于vue cli 通过命令行传参实现多环境配置
Jul 12 Javascript
深入理解JavaScript 中的匿名函数((function() {})();)与变量的作用域
Aug 28 Javascript
jquery获取元素到屏幕四周可视距离的方法
Sep 05 jQuery
vue.js的双向数据绑定Object.defineProperty方法的神奇之处
Jan 18 Javascript
JS实现瀑布流效果
Mar 07 Javascript
JS+Canvas实现五子棋游戏
Aug 26 Javascript
如何用JavaScript检测当前浏览器是无头浏览器
Apr 27 #Javascript
如何利用js在两个html窗口间通信
Apr 27 #Javascript
如何使JavaScript休眠或等待
Apr 27 #Javascript
JavaScript 实现页面滚动动画
如何用JS实现网页瀑布流布局
分享几个JavaScript运算符的使用技巧
Apr 24 #Javascript
JavaScript 防篡改对象的用法示例
Apr 24 #Javascript
You might like
搜索引擎技术核心揭密
2006/10/09 PHP
PHP和.net中des加解密的实现方法
2013/02/27 PHP
关于php 接口问题(php接口主要也就是运用curl,curl函数)
2013/07/01 PHP
jQuery+PHP+ajax实现微博加载更多内容列表功能
2014/06/27 PHP
php实现模拟post请求用法实例
2015/07/11 PHP
Yii2中简单的场景使用介绍
2017/06/02 PHP
解析arp病毒背后利用的Javascript技术附解密方法
2007/08/06 Javascript
返回顶部按钮响应滚动且动态显示与隐藏
2014/10/14 Javascript
Node.js中的模块机制学习笔记
2014/11/04 Javascript
Javascript中的Callback方法浅析
2015/03/15 Javascript
微信小程序 教程之数据绑定
2016/10/18 Javascript
div中文字内容溢出常见的解决方法
2017/03/16 Javascript
vue-cli 自定义指令directive 添加验证滑块示例
2017/10/19 Javascript
jquery中有哪些api jQuery主要API
2017/11/20 jQuery
vue 过滤器filter实例详解
2018/03/14 Javascript
JS实现统计字符串中字符出现个数及最大个数功能示例
2018/06/04 Javascript
基于jquery实现九宫格拼图小游戏
2018/11/30 jQuery
jQuery实现的自定义轮播图功能详解
2018/12/28 jQuery
微信公众平台 客服接口发消息的实现代码(Java接口开发)
2019/04/17 Javascript
详解vuex的简单todolist例子
2019/07/14 Javascript
Weex开发之地图篇的具体使用
2019/10/16 Javascript
Javascript表单序列化原理及实现代码详解
2020/10/30 Javascript
vue中如何添加百度统计代码
2020/12/19 Vue.js
import的本质解析
2017/10/30 Python
HTML5语义化元素你真的用对了吗
2019/08/22 HTML / CSS
英国在线药房:Express Chemist
2019/03/28 全球购物
世界经理人咨询有限公司面试
2014/09/23 面试题
好矿嫂事迹材料
2014/01/21 职场文书
企业法人授权委托书
2014/04/03 职场文书
人力资源管理专业应届生求职信
2014/04/24 职场文书
优秀三好学生事迹材料
2014/08/31 职场文书
作风转变年心得体会
2014/10/22 职场文书
自荐信模板大全
2015/03/27 职场文书
企业安全隐患排查治理制度
2015/08/05 职场文书
Python selenium模拟网页点击爬虫交管12123违章数据
2021/05/26 Python
spring项目中切面及AOP的使用方法
2021/06/26 Java/Android