1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-19 12:16:17 -05:00
denoland-deno/docs/getting_started/first_steps.md

145 lines
4.5 KiB
Markdown
Raw Normal View History

2020-05-07 00:21:13 +02:00
## First steps
2020-05-26 16:08:23 +02:00
This page contains some examples to teach you about the fundamentals of Deno.
2020-05-07 00:21:13 +02:00
This document assumes that you have some prior knowledge of JavaScript,
especially about `async`/`await`. If you have no prior knowledge of JavaScript,
2020-05-08 23:21:44 +02:00
you might want to follow a guide
2020-05-07 00:21:13 +02:00
[on the basics of JavaScript](https://developer.mozilla.org/en-US/docs/Learn/JavaScript)
before attempting to start with Deno.
### Hello World
Deno is a runtime for JavaScript/TypeScript which tries to be web compatible and
use modern features wherever possible.
2020-05-07 00:21:13 +02:00
2020-05-26 16:08:23 +02:00
Browser compatibility means a `Hello World` program in Deno is the same as the
one you can run in the browser:
2020-05-07 00:21:13 +02:00
```ts
2020-05-07 00:21:13 +02:00
console.log("Welcome to Deno 🦕");
```
Try the program:
```shell
deno run https://deno.land/std@$STD_VERSION/examples/welcome.ts
2020-05-07 00:21:13 +02:00
```
### Making an HTTP request
Many programs use HTTP requests to fetch data from a webserver. Let's write a
small program that fetches a file and prints its contents out to the terminal.
2020-05-07 00:21:13 +02:00
Just like in the browser you can use the web standard
[`fetch`](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API) API to
make HTTP calls:
```ts
2020-05-07 00:21:13 +02:00
const url = Deno.args[0];
const res = await fetch(url);
const body = new Uint8Array(await res.arrayBuffer());
await Deno.stdout.write(body);
```
2020-05-15 17:02:11 -04:00
Let's walk through what this application does:
2020-05-07 00:21:13 +02:00
1. We get the first argument passed to the application, and store it in the
`url` constant.
2. We make a request to the url specified, await the response, and store it in
the `res` constant.
2020-05-07 00:21:13 +02:00
3. We parse the response body as an
[`ArrayBuffer`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer),
await the response, and convert it into a
2020-05-07 00:21:13 +02:00
[`Uint8Array`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Uint8Array)
to store in the `body` constant.
4. We write the contents of the `body` constant to `stdout`.
2020-05-07 00:21:13 +02:00
Try it out:
```shell
deno run https://deno.land/std@$STD_VERSION/examples/curl.ts https://example.com
2020-05-07 00:21:13 +02:00
```
You will see this program returns an error regarding network access, so what did
we do wrong? You might remember from the introduction that Deno is a runtime
which is secure by default. This means you need to explicitly give programs the
permission to do certain 'privileged' actions, such as access the network.
2020-05-07 00:21:13 +02:00
Try it out again with the correct permission flag:
```shell
deno run --allow-net=example.com https://deno.land/std@$STD_VERSION/examples/curl.ts https://example.com
2020-05-07 00:21:13 +02:00
```
### Reading a file
Deno also provides APIs which do not come from the web. These are all contained
in the `Deno` global. You can find documentation for these APIs on
[doc.deno.land](https://doc.deno.land/https/github.com/denoland/deno/releases/latest/download/lib.deno.d.ts).
Filesystem APIs for example do not have a web standard form, so Deno provides
its own API.
In this program each command-line argument is assumed to be a filename, the file
is opened, and printed to stdout.
```ts
const filenames = Deno.args;
for (const filename of filenames) {
const file = await Deno.open(filename);
2020-05-07 00:21:13 +02:00
await Deno.copy(file, Deno.stdout);
file.close();
}
```
The `copy()` function here actually makes no more than the necessary
kernel→userspace→kernel copies. That is, the same memory from which data is read
2020-05-07 00:21:13 +02:00
from the file, is written to stdout. This illustrates a general design goal for
I/O streams in Deno.
Try the program:
```shell
deno run --allow-read https://deno.land/std@$STD_VERSION/examples/cat.ts /etc/passwd
2020-05-07 00:21:13 +02:00
```
2020-05-26 16:08:23 +02:00
### TCP server
2020-05-07 00:21:13 +02:00
2020-05-26 16:08:23 +02:00
This is an example of a server which accepts connections on port 8080, and
returns to the client anything it sends.
2020-05-07 00:21:13 +02:00
```ts
const hostname = "0.0.0.0";
const port = 8080;
const listener = Deno.listen({ hostname, port });
console.log(`Listening on ${hostname}:${port}`);
2020-05-07 00:21:13 +02:00
for await (const conn of listener) {
Deno.copy(conn, conn);
}
```
For security reasons, Deno does not allow programs to access the network without
explicit permission. To allow accessing the network, use a command-line flag:
```shell
deno run --allow-net https://deno.land/std@$STD_VERSION/examples/echo_server.ts
2020-05-07 00:21:13 +02:00
```
To test it, try sending data to it with netcat:
```shell
$ nc localhost 8080
hello world
hello world
```
Like the `cat.ts` example, the `copy()` function here also does not make
unnecessary memory copies. It receives a packet from the kernel and sends it
back, without further complexity.
2020-05-07 00:21:13 +02:00
### More examples
You can find more examples, like an HTTP file server, in the `Examples` chapter.