# Denoの開発環境をVSCodeで作る ###### tags: `解説資料` ## はじめに 今回の内容は、2021年1月4日時点での方法です。 Denoは発展途上のランタイムなので、より良い方法があるよというときにはコメントにてお知らせしていただけると嬉しいです。 また、VSCode、Denoはインストール済みという前提で話を進めていきますので、まだインストールしていない方は先に済ませておくことをお勧めします。 ## 1.Deno拡張機能のインストール VSCodeにはありがたいことに、既にDenoの拡張機能が用意されています。 [Deno - Visual Studio Marketplace](https://marketplace.visualstudio.com/items?itemName=denoland.vscode-deno) ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/255360/d6f8092e-9d3c-61f3-1a23-d2527925aa97.png) Installを押してインストールしましょう。 ## 2.Deno拡張機能を有効化 Deno拡張機能を使うためには有効化する必要があります。VSCode全体で有効化することもできますが今回は作業フォルダ内でのみDeno拡張機能を有効化します。 ①左下の設定アイコンから「設定/Settings」をクリック(またはショートカットキー`Ctrl+,`)。 ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/255360/f1cd339b-64d5-0641-5cbc-78fe8539459d.png) ②下の画像の赤線部分をクリックしてWorkspaceの設定画面に変更。 ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/255360/64ee9b41-2bf0-4ee8-49c8-be7afb97f1c3.png) ③上の検索窓から「Deno」と検索。すると、「Deno: Enable」という項目があると思うので、チェックを入れる。 ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/255360/013883da-3a70-9c54-4bf4-e17cb5ef5f2a.png) ## 3.デバッグ設定ファイルの作成 プログラムを途中で止めて確認をすることができるようにデバッグ設定ファイルを作っていきます。 既に、「.vscode」というフォルダが作られていると思うので、その中に以下に示すデバッグ環境用のファイル「launch.json」を作ってください。 ```json:launch.json { "version": "0.2.0", "configurations": [{ "name": "Deno", "type": "node", "request": "launch", "cwd": "${workspaceFolder}", "runtimeExecutable": "deno", "runtimeArgs": ["run", "--inspect-brk", "-A", "${file}"], "port": 9229, "outputCapture": "std" }] } ``` ## 4.プログラム実行 以上の手順でVSCodeの設定は終わりです。 試しに`test.ts`を作成して、`Deno.`と入力してみてください。Deno拡張機能が有効化されていれば下のように補間の関数などがたくさん出てくると思います。 ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/255360/1a920ab4-7683-4c90-735c-c3113b55dd66.png) 次は、サンプルコードを動かしてみましょう。`test.ts`の中身を全部消して、次のプログラムを書き込んでください。 ```typescript:test.ts import { serve } from "https://deno.land/std@0.83.0/http/server.ts"; const s = serve({ port: 8880 }); console.log("http://localhost:8880/"); for await (const req of s) { req.respond({ body: "Hello World\n" }); } ``` 恐らく初めは1行目のリンクのところに波線が引かれていると思います。 ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/255360/cf29b6d3-26f8-233e-d7da-d7ac027db033.png) これは1度実行すると消えると思うので、さっそく実行していきます。`F5`キーを押すと実行できます。 デバッグコンソールに「[http://localhost:8880](http://localhost:8880)」と出力されたら、そのアドレスにブラウザからアクセスしてみましょう。「Hello World」と表示されれば設定完了です! ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/255360/3950a3ac-185a-47ea-83ee-0cc9f40b1bea.png)