2020-05-07 00:21:13 +02:00
|
|
|
# Introduction
|
|
|
|
|
|
|
|
Deno is a JavaScript/TypeScript runtime with secure defaults and a great
|
|
|
|
developer experience.
|
|
|
|
|
|
|
|
It's built on V8, Rust, and Tokio.
|
|
|
|
|
2020-12-28 23:05:29 +00:00
|
|
|
## Feature highlights
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
- Secure by default. No file, network, or environment access (unless explicitly
|
|
|
|
enabled).
|
|
|
|
- Supports TypeScript out of the box.
|
|
|
|
- Ships a single executable (`deno`).
|
|
|
|
- Has built-in utilities like a dependency inspector (`deno info`) and a code
|
|
|
|
formatter (`deno fmt`).
|
|
|
|
- Has
|
2020-07-14 15:24:17 -04:00
|
|
|
[a set of reviewed (audited) standard
|
2021-02-11 20:14:23 +01:00
|
|
|
modules](https://github.com/denoland/deno_std) that are guaranteed to work
|
|
|
|
with Deno.
|
2021-04-01 02:20:43 -07:00
|
|
|
- Can bundle scripts into a single JavaScript file.
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
## Philosophy
|
|
|
|
|
|
|
|
Deno aims to be a productive and secure scripting environment for the modern
|
|
|
|
programmer.
|
|
|
|
|
|
|
|
Deno will always be distributed as a single executable. Given a URL to a Deno
|
|
|
|
program, it is runnable with nothing more than
|
2021-03-05 11:22:28 +00:00
|
|
|
[the ~25 megabyte zipped executable](https://github.com/denoland/deno/releases).
|
2020-05-07 00:21:13 +02:00
|
|
|
Deno explicitly takes on the role of both runtime and package manager. It uses a
|
|
|
|
standard browser-compatible protocol for loading modules: URLs.
|
|
|
|
|
|
|
|
Among other things, Deno is a great replacement for utility scripts that may
|
2020-12-28 23:05:29 +00:00
|
|
|
have been historically written with Bash or Python.
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
## Goals
|
|
|
|
|
2021-04-01 02:20:43 -07:00
|
|
|
- Ship as just a single executable (`deno`).
|
2020-12-28 23:05:29 +00:00
|
|
|
- Provide secure defaults.
|
2020-05-07 00:21:13 +02:00
|
|
|
- Unless specifically allowed, scripts can't access files, the environment, or
|
|
|
|
the network.
|
2020-12-28 23:05:29 +00:00
|
|
|
- Be browser-compatible.
|
|
|
|
- The subset of Deno programs which are written completely in JavaScript and
|
|
|
|
do not use the global `Deno` namespace (or feature test for it), ought to
|
|
|
|
also be able to be run in a modern web browser without change.
|
|
|
|
- Provide built-in tooling to improve developer experience.
|
|
|
|
- E.g. unit testing, code formatting, and linting.
|
2021-04-01 02:20:43 -07:00
|
|
|
- Keep V8 concepts out of user land.
|
2020-12-28 23:05:29 +00:00
|
|
|
- Serve HTTP efficiently.
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
## Comparison to Node.js
|
|
|
|
|
2020-09-27 23:01:32 -07:00
|
|
|
- Deno does not use `npm`.
|
|
|
|
- It uses modules referenced as URLs or file paths.
|
2020-05-07 00:21:13 +02:00
|
|
|
- Deno does not use `package.json` in its module resolution algorithm.
|
|
|
|
- All async actions in Deno return a promise. Thus Deno provides different APIs
|
|
|
|
than Node.
|
|
|
|
- Deno requires explicit permissions for file, network, and environment access.
|
|
|
|
- Deno always dies on uncaught errors.
|
2021-04-01 02:20:43 -07:00
|
|
|
- Deno uses "ES Modules" and does not support `require()`. Third party modules
|
|
|
|
are imported via URLs:
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
```javascript
|
2020-07-31 11:12:20 +02:00
|
|
|
import * as log from "https://deno.land/std@$STD_VERSION/log/mod.ts";
|
2020-05-07 00:21:13 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
## Other key behaviors
|
|
|
|
|
2021-04-01 02:20:43 -07:00
|
|
|
- Fetch and cache remote code upon first execution, and never update it until
|
2020-05-07 00:21:13 +02:00
|
|
|
the code is run with the `--reload` flag. (So, this will still work on an
|
|
|
|
airplane.)
|
|
|
|
- Modules/files loaded from remote URLs are intended to be immutable and
|
|
|
|
cacheable.
|