TypeScriptを開発するに当たってNode.jsが必要になります。まずはNode.jsのおさらいをしましょう。
Node.jsとは、ChromeのV8 JavaScriptエンジンで動作するJavaScript環境です。Server-Side JavaScriptと説明される場合が多いのですが開発初期はサーバー(Linux)のみ動作対象OSだったためその名残となっています。2011年7月15日Node.js v0.5.1からWindowsをサポート。2011年11月11日リリースNode.js v0.6.1からはMacをサポートするようになりました。
Node.jsにはJavaScriptに存在しないAPIが存在します。わかりやすい関数はFileSystem(fs)です。fs.readFile(path)
はPC上のファイルを読み込むことができます。fs.writeFile(path , data)
はPC上のディレクトリにファイル書き込みを行うことができます。では、Node.jsは機能が増えたJavaScriptかと言われるとそうではありません。Node.jsではwindows.alert()
などといったブラウザでしか動作しないAPIはありません。
JavaScriptはブラウザ上で動作するプログラミング言語です。それに対してNode.jsはデスクトップまたはサーバー上で動作させる環境となります。
TypeScriptの開発環境にNode.jsが必要な理由はTypeScriptコンパイラ(tsc)を利用するためです。
Node.js公式ページがらダウンロードしてインストールを行うことができます。が、これはお勧めしません。なぜならばNode.jsの開発サイクルが速いためです。毎年10月に新しいバージョンのLTS版がリリースされます。
🧙♂ Tips: "LTS" Long Term Supportの略。長期サポートの安定版。
1台のPC上にNode.jsを利用したプロジェクトが1つ、かつ、Node.jsのアップデートを行う予定がない場合は問題がありませんが複数のプロジェクトがあり、それらが異なったバージョンの場合に支障が出てきます。言語仕様の変更などにより正しく動作する保証はありません。使用するフレームワークが最新のLTSをサポートしていない場合や脆弱性が明らかになりアップデートする必要も出てくるでしょう。 これらの問題を回避するためにNVMを利用します。NVMはnode version managerの略で複数のNode.jsを複数インストールし、バージョン切り替えを行うことができます。
nvm-sh/nvmを利用します。 https://github.com/nvm-sh/nvm インストールをする際にgitコマンドが必要となります。macOS 10.9以降は/usr/bin/gitが廃止されたためXcodeをインストールすることお勧めします。Xcodeのインストールを行うと同時にgitも自動的にインストールされます。
ターミナル(Terminal.app)からインストールスクリプトを実行します。スクリプトのパスにバージョンが記載されています。最新バージョンはnvm-sh/nvm公式ページより確認してください。2020年8月現在ではv0.35.3となります。
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.35.3/install.sh | bash
スクリプト実行後、nvmコマンドのPATHを設定します。~/.bash_profile
を作成しexport文を追加します。
export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && printf %s "${HOME}/.nvm" || printf %s "${XDG_CONFIG_HOME}/nvm")"[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
PATHを再読込させるために、ターミナルでsource ~/.bash_profile
コマンドを実行してください。
nvmコマンドの確認のためnvm --version
を実行します。インストールしたバージョンが表示されれば成功です。
nvmを利用し最新版のNode.jsをインストールします。Node.jsのインストールが行えるバージョン一覧はnvmコマンドを利用するとよいでしょう。nvm ls-remote
を実行します。
$ nvm ls-remote・・・・v12.13.0 (LTS: Erbium)v12.13.1 (LTS: Erbium)v12.14.0 (LTS: Erbium)v12.14.1 (LTS: Erbium)v12.15.0 (LTS: Erbium)v12.16.0 (Latest LTS: Erbium)v13.0.0v13.0.1v13.1.0v13.2.0v13.3.0v13.4.0v13.5.0v13.6.0v13.7.0v13.8.0
この場合はv12.16.0がLTSの最新版だと言うことがわかると思います。Node.js v12.16.0をインストールする場合はnvm install バージョン
を実行します。
$ nvm install v12.16.0
インストール後、nvm alias default バージョン
を実行します。これはデフォルトで使用するバージョンを指定するためのコマンドです。今はひとつのバージョンのみインストールしているため恩恵は感じられませんが覚えておきましょう。
$ nvm alias default v12.16.0
最後にnode -v
でインストール・デフォルト設定したバージョンが表示されることを確認します。
$ node -vv12.16.0
nvm-windowsを利用します。 https://github.com/coreybutler/nvm-windows 公式ページのreleaseからnvm-setup.zipをダウンロード・インストールを行うだけです。ダウンロードダイアログが表示されるので文言を読み、インストールを行ってください。
インストール後はPCの再起動を行います。これはPAHTを確実に通すためです。
nvmコマンドの確認のためにコマンドプロンプトまたはPowerShellを起動しnvm version
を実行します。インストールしたバージョンが表示されれば成功です。
nvmを利用し最新版のNode.jsをインストールします。Node.jsのインストールが行えるバージョン一覧はnvmコマンドを利用するとよいでしょう。nvm list available
を実行します。
C:\>nvm list available| CURRENT | LTS | OLD STABLE | OLD UNSTABLE ||--------------|--------------|--------------|--------------|| 13.9.0 | 12.16.1 | 0.12.18 | 0.11.16 || 13.8.0 | 12.16.0 | 0.12.17 | 0.11.15 || 13.7.0 | 12.15.0 | 0.12.16 | 0.11.14 || 13.6.0 | 12.14.1 | 0.12.15 | 0.11.13 || 13.5.0 | 12.14.0 | 0.12.14 | 0.11.12 || 13.4.0 | 12.13.1 | 0.12.13 | 0.11.11 || 13.3.0 | 12.13.0 | 0.12.12 | 0.11.10 || 13.2.0 | 10.19.0 | 0.12.11 | 0.11.9 || 13.1.0 | 10.18.1 | 0.12.10 | 0.11.8 || 13.0.1 | 10.18.0 | 0.12.9 | 0.11.7 || 13.0.0 | 10.17.0 | 0.12.8 | 0.11.6 || 12.12.0 | 10.16.3 | 0.12.7 | 0.11.5 |
この場合はv12.16.0がLTSの最新版だと言うことがわかると思います。Node.js v12.16.0をインストールする場合はnvm install バージョン
を実行します。
C:\>nvm install 12.16.0
インストール後、nvm use バージョン
を実行します。これはデフォルトで使用するバージョンを指定するためのコマンドです。今はひとつのバージョンのみインストールしているため恩恵は感じられませんが覚えておきましょう。
C:\>nvm use 12.16.0
最後にnode -v
でインストール・デフォルト設定したバージョンが表示されることを確認します。
C:\>node -vv12.16.0
シェアで決めつけるのも好きではありませんが、Visual Studio Codeが一番良く使われています。無料であり、インストールすれば拡張機能なしでもコーディングを行うことができます。
TypeScript、Visual Studio Codeも主にMicrosoftが中心に開発されているため相性がよいのかもしれません。
🧙♂ Tips: Visual Studio Codeは主にTypeScriptで開発されています。またVS Codeと略すことが多いです。
対応OSはWindows、Mac、Linuxのいずれにも対応しています。ダウンロードサイトから環境にあったインストーラーをダウンロード・インストールを行ってください。 https://code.visualstudio.com/download
Windowsの場合はコマンドプロンプト、またはpowershell。Macの場合はTerminalからtypescriptコンパイラをインストールします。
npm install -g typescript
tsc
コマンドが実行できるかtsc -v
コマンドで確認します。
tsc -vVersion 3.7.5
表示されるバージョンはインストールした時点でのLTSになるので上記のバージョンとは異なっていても問題ありません。