JavaScript

[環境構築]nodejsとtypescriptを用いた環境構築方法の備忘録

仕事ではJavaがメインですけど、家ではJavaScriptをメインで触っていたりします。

直近1ヶ月で触ってた内容としては「React」「React + Electron」辺りをやっていました。純粋なnodejsの環境で何か触ってたのって多分3ヶ月ほどは前かなーと思います。
そうなるとですね、忘れるんですよ。どうやって環境構築したっけ?って。

なので、今回はさっと触りたいときにどういう環境で構築してたかを自分で思い出すような備忘録となります。

必要な設定を行ってGitHubリポジトリに置いておけばいいんじゃないかなって思ったりしますが、GitHub使えないパターンもあるかと思うのでそういった場合を想定という感じで。

nodejs in typescript環境構築に必要なものまとめ

  • エディタ(後述)
  • nodejs
  • npm

ざっくりですけど、上3つあれば大体なんとかなるかなーという感じです。

エディタについて

Visual Studio Code、Coda2、Atom、Sublime Text、etc…

多種多様なエディタがあるかと思うので、お好みに合わせてって感じです。ここではVisual Studio Codeを用いて実施しています。

以降では環境構築を実施していきます。
Visual Studio Codeのインストール、nodejsのインストール方法などは事前に完了している前提で、ここでは省略します。

npmとnodeのバージョン確認

npm -v
node -v

バージョン確認はターミナル上で上記のコマンドを打ち込むことで確認できます。

画像にあるようなバージョン情報が返ってきていない場合は環境パス、インストール自体できていない可能性があるので、返却された情報を検索してみてください。

nodejs in typescriptの環境構築

nodejsとnpmのバージョンも確認したので、実際に作っていきたいと思います。

環境構築したいディレクトリに移動した後に、下記コマンドを実施します。

package.jsonの作成

npm init -y

package.jsonできるので一旦OK

TypeScriptとts-nodeをコマンド実行

npm install typescript ts-node

installをiに省略するとかはお任せ。

次は上記を実行。
ts-nodeは作ったコードを手軽に実行したいため導入。

無事node_modulesを引っ張ってくることができました。

nodejs用の型定義

npm install @types/node -D

tsconfig.json作成

npx tsc --init

tsconfig.jsonファイルが作られます。設定等の詳細は下記ページなんかが参考になるかなーと思います。(私自身そこまで詳しくないので、そのうちしっかり調べたいなと思います)

tsconfig.jsonを設定する

tsconfig.jsonの主要オプションを理解する

あったら良いかなー?とか、ちょっと眺めてみて以下に設定しました。
もっと簡単に設定してもいいかと思いますが、それは個々人の設定ということでよしなに。

{
  "compilerOptions": {
    /* Projects */
    "incremental": true,

    /* Language and Environment */
    "target": "es2022",
    "lib": ["dom", "es2022"],

    /* Modules */
    "module": "commonjs",
    "moduleResolution": "node",
    "resolveJsonModule": true,

    /* JavaScript Support */
    "allowJs": true,

    /* Emit */
    "sourceMap": true,

    /* Interop Constraints */
    "esModuleInterop": true,

    /* Type Checking */
    "strict": true,
    "noUnusedLocals": true,
    "noUnusedParameters": true,
    "noImplicitReturns": true,
    "noFallthroughCasesInSwitch": true,

    /* Completeness */
    "skipLibCheck": true
  }
}

実際にお試し

main.tsを作成(ファイル名は適当に。拡張子はtypescriptなので.ts)
簡単なコードを作成
ターミナルで実行コマンドを入力

npx ts-node main.ts

※ローカルにts-nodeをインストールしたんですけどパスが上手く通ってないのかして、一旦この場ではnpxで対処

というわけで、なんとか無事?に実行することができました。

あとがき

ts-nodeの実行に若干躓いて調べながら書いてたら結構時間がかかっちゃいましたね…。

調べてて思ったのがMacとかだとその辺りの設定が楽だったりするんですかね?

何にせよ、これで久しぶりにちょっとしたツール作りたいなー、node環境整えるかーといったときに、「あれ、node環境ってどう作ったっけ?」になったら、このページ見て作ればいいやって備忘録の出来上がりです。

※あくまで個人的に使う意味で十分なので、もっと詳細に設定したいとかしっかり整えたい場合は環境構築系のページもたくさんあるので、調べてみてください。

[アウトプット]最近Git操作はTortoiseGitじゃなくて、極力コマンドを使っている前のページ

[Electron]フロントで作った配列をバックで抜き出して使おうと思ったらmap関数でちょっと嵌った話次のページ

ピックアップ記事

  1. [グラブル]よろず屋シェロなんばマルイ出張所遊びに行ってみた[番外]
  2. [猫](前編)子猫の成長と思い出。写真で残そう!我が家のソマリ、ミコの場合
  3. [アズールレーン]今話題のアズールレーンをプレイしたらドハマリした件
  4. [グラブル]召喚石確率UP召喚石欲しいから70連してみたら
  5. [猫]ソマリを飼うまでの軌跡。ソマリのミコちゃんとの出会い

関連記事

  1. JavaScript

    [Electron]フロントで作った配列をバックで抜き出して使おうと思ったらmap関数でちょっと嵌っ…

    タイトルどおりの内容です。フロント(Web側)でinputに入った値を…

  2. JavaScript

    [Electron]electron-storeでgetとset呼び出そうとしたらエラーで呼び出しで…

    今回結構長く何でだろう?って悩んだので忘れないと思うんですが、備忘録と…

  3. git

    [アウトプット]最近Git操作はTortoiseGitじゃなくて、極力コマンドを使っている

    QiitaとかZennとか見ていると、アウトプットが大事だという記事を…

最近の記事

  1. Cat-l
PAGE TOP