• Why Deno is Perfectly Ready To Take Over Node.js Now
  • Charuka Herath
  • The Nuggets translation Project
  • Permanent link to this article: github.com/xitu/gold-m…
  • Translator: samyu2000
  • Proofreader: Inchill, regon-cao

Why is Deno completely replacing Node.js today

Deno is a new tool for writing server-side JavaScript. It has the same functionality as Node. Its inventor is also the inventor of Node.js. Like Node.js, it uses the V8 JavaScript engine. Some functionality is also implemented in Rust and JavaScript. Deno has been very popular since its launch. You can check it out by visiting its Github repository.

Before going any further, we need to install the Deno environment on our computer. On Mac and Linux, we use the shell to run commands:

curl -fsSL https://deno.land/x/install/install.sh | sh
Copy the code

On Windows we use PowerShell to run commands:

iwr https://deno.land/x/install/install.ps1 -useb | iex
Copy the code

You can also install Deno using package management tools, such as Homwbrew for Mac, Chocolatey, Scoop, or Cargo for Windows (available for Windows,macOS, and Linux) :

brew install deno

choco install deno

scoop install deno

cargo install deno
Copy the code

Now let’s start with a simple TypeScript file and explore the use of Deno. In this file, we can use all the data types in the runtime environment. This means that we can write strongly typed code, get documentation hints directly from the IDE, and don’t need to create a TS configuration file. The runtime features are available from the Deno namespace.

We create a TypeScript file in our working directory called main.ts. Next, use console.log to print the working directory of the current file system:

console.log(Deno.cwd());
Copy the code

We can use the following command to execute the script:

deno run main.ts
Copy the code

1. Built-in permission system

Running the code above throws an error because Deno has safe mode enabled by default. Deno is superior to Node in security handling. For example, in order for the above program to run properly, you need to grant access to the file system or network.

In Node, if you import a package that has been tampered with by someone else and that package has been injected with malicious code, the files on the entire machine can be deleted. In Deno, tampered packages cannot do anything without authorization unless you state that you allow the program to delete all files.

Deno takes security very seriously, so it designed a built-in permissions system. You don’t have to worry about other packages doing anything against your intentions on your machine or server.

Therefore, we need to grant various permissions when running the program. Now we use allow-read to declare that the file system is allowed to read:

Deno run -- allow-read main.tsCopy the code

2. Based on the Promise

Developers using Deno seem to be more concerned with security. But I think the beauty of Deno is that any asynchronous operation is based on promises (goodbye, callback function).

As you can see, we can use the FETCH API to initiate a web request just as we would in a browser. Since Deno supports top-level WAIT, we don’t even need to define asynchronous functions. And we can parse promises without additional boilerplate code:

const url = Deno.args[0];

const res = await fetch(url);
Copy the code

3. Deno aims to make code as compatible with as many browsers as possible

Deno provides the Window object, which contains life cycle events that can be listened on. Obviously, this makes life cycle management easier:

window.onload = e= > console.log (' good bye nodejs');Copy the code

Oh, I remember. Deno can also execute WebAssembly programs. As stated on the WebAssembly website, “WebAssembly (Wasm for short) is a stack-based binary instruction format for virtual machines.”

const wbs = new Uint8Array([61.63.73]);

const wsm = new WebAssembly.Module(wbs);
Copy the code

4. A standard library of common functions is provided

Further, Deno provides a standard library with some very useful packages for dealing with dates, times, colors, and features that aren’t built into the browser. So, you can use Deno to invoke certain browser functions.

The benefit of the standard library is that you can use it in all Deno projects without importing modules from NPM.

“Good code is short, simple, and symmetrical, and the challenge is understanding how to achieve that.” – Sean Parent

5. There aren’t tons of Node and Modules packages

Instead, we import packages using modern ES Module syntax. Remote modules are represented by their URLS. The first time you run the script, these programs are downloaded locally and cached. JSON packages do not exist and code can be referenced from any URL. This is similar to how a browser works.

As I mentioned earlier, there is no module directory in Deno. All module-related configuration takes place in the background. All dependencies are also stored locally, so you don’t have to worry about cumbersome module directories or bulky package.json files.

import { Response } from"HTTPS:HTTP / / / deno. Land/[email protected] / server. The ts ";

import { Server } from"HTTPS:HTTP / / / deno. Land/[email protected] / server. The ts ";
Copy the code

6. Provide a series of standard modules to achieve common functions

Deno also provides a series of standard modules to implement common functions. For example, we can import server functionality using HTTP modules. Next, we use it to create the server, which can be viewed as asynchronously mutable. We then have the server wait for each request and respond individually.

Figure 5: Simple server

That’s a brief introduction to Deno. If you need to learn more about Deno and related programming practices, please visit our website.

Conclusions and shortcomings

You should see that Deno has a lot more functionality than Node.js. Although it is powerful and has many good features, it is still in its early stages. Deno has only recently released its first release, which means many of its goals have yet to be met. Browser compatibility, for example, is not 100% compatible. Browser-related apis are yet to be implemented and will continue to be updated over time.

I also want to point out that don’t use Deno and NPM at the same time. This is actually a disadvantage because JavaScript is based on NPM. The problem is that not all packages are Deno compatible. Node-based apis are not yet available. So, you don’t understand why Node is so popular.

I think Deno is still some way from widespread use.

Thanks for reading this article! I hope you like it.

If you find any mistakes in your translation or other areas that need to be improved, you are welcome to the Nuggets Translation Program to revise and PR your translation, and you can also get the corresponding reward points. The permanent link to this article at the beginning of this article is the MarkDown link to this article on GitHub.


The Nuggets Translation Project is a community that translates quality Internet technical articles from English sharing articles on nuggets. The content covers Android, iOS, front-end, back-end, blockchain, products, design, artificial intelligence and other fields. If you want to see more high-quality translation, please continue to pay attention to the Translation plan of Digging Gold, the official Weibo, Zhihu column.