Deno會在短期內取代Node嗎?

轉載請註明出處:葡萄城官網,葡萄城爲開發者提供專業的開發工具、解決方案和服務,賦能開發者。

原文出處:https://blog.bitsrc.io/what-is-deno-and-will-it-replace-nodejs-a13aa1734a74

Deno是什麼?

Deno v1.0.0已於5月13日正式發佈。

其開發者爲Ryan Dahl,他的上一個項目是Node,相信我們大部分人都瞭解。

作爲Node之父,Ryan Dahl認爲Node自從他把項目移交出去後,Node的走向越來越背離了他的初衷,並且存在着很多無法解決的問題,所以他決心重新開發一個新的項目去解決這些問題,這個項目就名爲Deno。目標則是Destroy-node。

那麼,這樣是不是就意味着Deno即將替代Node,成爲Node的下一代產品?我們應不應該從現在就開始放棄Node開始使用Deno呢? 讓我們一起看看。

起源

在2018年,Ryan在柏林進行了一次演講,這是他第二次關於JS的公開演講,第一次再2009,那次是宣佈Node項目的誕生。

在這次演講中,除了主要介紹他認爲Node.js的幾大問題和不可避免的許多Bug外,在演講快結束時,他揭開了當時還是個小項目名爲Deno的面紗,因爲和node命名有着千絲萬縷的聯繫,那時大家認爲這個項目就是Node.js v2,它將會解決和完善ry提到那些問題。

兩年後的5月13日, Deno 1.0終於正式發佈了,它是一個全新的服務端JavaScript運行時,使用Rust而不是C++開發,由於Rust原生支持WebAssembly,所以它也能直接運行WebAssembly。基於Tokio平臺(它提供了所有JavaScript所需的異步操作),內置V8和tsc引擎,可直接解釋JavaScript和TypeScript。

安全集成

默認情況下,Node.js給你的訪問權限比較高,這意味着你擁有讀寫文件系統、對外發出請求、訪問環境變量等行爲。雖然作爲開發人員,擁有這種級別的訪問權限對開發過程非常好,但如果你在開發過程中有一點疏漏,將來對你的應用也會產生安全風險。

而在Deno這,默認情況下腳本不具有讀寫權限,必須顯式通過命令行參數來啓用或禁用對不同安全功能的訪問。因此,如果需要腳本能夠訪問/etc文件夾,可以通過下面命令行執行:

deno --allow-read = / etc myscript.ts

 

這就類似於其他平臺處理安全性的方式。如果你是Android用戶,那麼肯定有很多應用程序要求你允許它們訪問你手機內的不同資源,例如聯繫人、電話、文件夾等,同樣的概念也可以在這裏應用。通過將這些標誌用作執行腳本的命令行的一部分,你可以提供代碼所需的權限。

更完整的標準庫

自從Node的第一個版本發佈以來,JavaScript已經改進了它的標準庫,但與其他語言相比,它仍有相當長的路要走。Deno也試圖改進這一點,它聲稱擁有一個非常完整的標準庫,允許開發人員使用官方工具執行基本任務,而只需要對複雜任務使用外部庫(ala NPM)。

本質上,Deno開箱即用工具爲終端文本添加顏色,處理外部數據結構(如Binary、CSV、YAML和其他),生成UUID,甚至編寫WebSocket。還可以使用其他更基本的模塊,例如文件系統訪問、日期助手函數、http相關函數等等。

集成TypeScript

如果你對TypeScript非常熟悉,那麼使用Deno將會更加容易上手,因爲它原生可以直接運行TS。

另外,Deno不需要任何外部工具去支持多語言,它內部會根據文件後綴自動判斷其使用的語言解釋引擎。

雖然默認情況下Deno會處理很多事情,但您可以使用自己的tsconfig.json文件覆蓋配置:

deno run -c tsconfig.json [your-script.ts]

默認配置使用的是嚴格模式,因此如果發現任何不合格的代碼都會立即得到提示。

放棄NPM和node_modules

Deno決定完全放棄NPM和node_modules, 因爲npm邏輯越來越複雜,node.js對外部模塊幾乎沒有任何安全驗證措施,另外node_modules也越來越臃腫且難以管理。

 

那麼,Deno是如何處理依賴關係呢?它是通過url加載所有模塊的:

import * as log from "https://deno.land/std/log/mod.ts";

所以,Deno不再需要擁有一個集中的存儲庫,之前的package.json也不再需要了,現在通過在名爲deps.ts的文件中包含了模塊列表及其各自的URL,簡化了依賴管理。但版本管理控制怎麼辦呢?作者已經想到了,可在URL上指定包的版本,deps.ts的文件示意:

export { assert } from "https://deno.land/[email protected]/testing/asserts.ts";
export { green, bold } from "https://deno.land/[email protected]/fmt/colors.ts";

由於這個文件的存在,在內部運行時,依賴項將被重新導出,這就能讓應用程序的不同模塊都引用相同的源。

如果您想更新任何模塊的版本,可以通過修改deps.ts中URL的版本信息。另外,雖然沒有了node_modeules目錄,但依賴項仍然會下載並隱藏在你的硬盤中,供你離線使用,如通過需要重新下載,只需在命令中添加—reload命令即可。

 

還有什麼?

Deno還包括其他特性,比如自動測試器、調試器、文件監視器等開箱即用的工具。但其中一些只是語言提供的API,您需要編寫自己的工具才能使用它們。

以Deno.watchFS向您提供的文件監視器API爲例,如果你正在尋找類似於nodemon的解決方案,那麼你可以自己構建它。下面是一個解決類似問題的23行腳本:

 

最後,它會在短期內取代Node.js嗎?

雖然Deno的很多想法和理念非常好,也確實解決了很多問題。但作爲一個從Node發佈之初就開始用的團隊,我認爲PHP、Python甚至Ruby(更不用說Java或.NET)都不能與在後端擁有JavaScript和異步I/O模型相提並論。這些年來,Node(和JavaScript)不斷髮展,以滿足業界的需求。

在我看來,雖然Deno是以Destroy-node爲己任而開發的,但就目前來講,Deno取代Node仍不可能,Node的佔有率太高了,生態也足夠完善,基本屬於想要什麼功能都能在社區中找到,所以基本無需擔心。而Deno還在孵化初期,企業很難去放棄已經成熟的技術轉而投入更大的精力使用它。但它未來的前景還是令人期待的, 也許在越來越多的行業頭部企業分享過它們的使用經驗後,Deno的存在也會越來越爲人所知。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章