WindowsのVisutal Studio CodeでESLintとPrettierを使い、ファイル保存時に自動的にコードをフォーマットしてくれるようにする手順です。ここではNuxt.jsのプロジェクトで試してみます。
Nuxtのプロジェクト作成
プロジェクト作成コマンド実行
コマンドプロンプトを開き、適当な作業フォルダでプロジェクトを作成します。
1 |
npx create-nuxt-app SampleProject |
以下の設定で実行してみました。Linting toolsでESLintやPrettierを選択できますが後で自分でインストールするので選択してません。
data:image/s3,"s3://crabby-images/67cbb/67cbbbbc3de4495c996b99eef9eb1a68ae4b5d37" alt=""
ESLintとPrettierのインストール
ESLintとPrettierのインストールコマンド実行
作成したプロジェクトに移動しESLintとPrettierをインストールします。開発用の機能なので-Dオプションを付けます。
1 2 |
cd SampleProject npm install -D eslint prettier |
ESLintとPrettierの連携設定
続いてESLintとPrettierの両者が整形処理を実行してしまわないようにする設定をします。先ほどのコマンドに続けて、以下コマンドを実行します。
1 |
npm install -D eslint-config-prettier |
ESLintの初期化
node_modules\.binフォルダの中にeslintのツールが入っているので、以下のコマンドでESLintの設定ファイルを作成します。
1 |
node_modules\.bin\eslint --init |
いくつか質問されるので適当に答えます。
data:image/s3,"s3://crabby-images/390ad/390ad213a0303156988671c7106a76ad017bc741" alt=""
.eslintrcの編集
プロジェクトフォルダに「.eslintrc.*」という名前の設定ファイルが作成されているので開きます。「What format do you want your config file to be in?」 の質問で答えた内容に応じて拡張子が.jsだったり.jsonだったりします。
以下は.jsonの例です。extendsの最後にprettierと追記します。extendsの一番最後に記述しないとうまく動かないことがあるそうです。
data:image/s3,"s3://crabby-images/1e7e6/1e7e6c8d0ec0f02ed89662c50bcbeb23964d535d" alt=""
ちなみに.eslintrcの形式がJavaScriptだとこんな感じでエラー扱いになってしまって直すのにひと手間かかるので私は.eslintrcの形式はJSONが好みです。
data:image/s3,"s3://crabby-images/d4733/d4733b8bd467198d24d1b6834c0fa009361d6d7b" alt=""
VSCodeの拡張機能インストール
拡張機能のインストール
VSCodeの画面左側にある拡張機能タブを開いてESLintを検索し、インストールをクリックします。
data:image/s3,"s3://crabby-images/f3b24/f3b243932ca277dbe6cba40fad141889998539e1" alt=""
同様にPrettierを検索し、インストールをクリックします。
data:image/s3,"s3://crabby-images/4d8e5/4d8e5bf87d0121bd6d1b45861dbf0338a8fe45fb" alt=""
保存時にフォーマットするよう設定
メニューからファイル→ユーザー設定→設定を選択。もしくは「Ctrl + ,」を実行。
data:image/s3,"s3://crabby-images/f035d/f035da78f12ce1204860d81b428ecc56c7135c4d" alt=""
検索欄にformatと入力して検索し、「Format On Save」にチェックを入れます。
data:image/s3,"s3://crabby-images/cf09f/cf09fe9116c49a940f909a8bcf07fd8efd091c6b" alt=""
フォーマッタの指定
何か適当なJavaScriptファイルを開きます。ここではnuxt.config.jsを使います。その状態でShift+Alt+Fを押すとフォーマットしてくれますが以下のようがダイアログが表示されますので「構成」ボタンをクリックします。
data:image/s3,"s3://crabby-images/c2089/c2089032afd5d048da3e38003a97e07f2c97893b" alt=""
フォーマッタの選択を迫られるのでPrettierを選択します。
data:image/s3,"s3://crabby-images/ea8ce/ea8ceb5d2b800f10ac2e2b16bb6e6b3ed7d059af" alt=""
他の形式のファイル(.vueとか.jsonとか)を自動フォーマットしたい場合も同様です。
確認
ファイルを保存するとPrettierのフォーマットが走ることを確認します。
data:image/s3,"s3://crabby-images/5cf59/5cf59c329a5ea63ed95289a32ac20a7dda167f50" alt=""
ESLintが構文チェックもしてくれています。
data:image/s3,"s3://crabby-images/125f6/125f6f054dbbc983442aa5c9811e2daf6bb46fd6" alt=""
settings.jsonで直接編集
保存時の自動フォーマットやフォーマッタの指定はsettings.jsonに保存されています。直接開いて編集しても同様の結果になります。こちらを直接編集する方法がよく紹介されていますが、個人的には間違いにくいGUIの方が好きです。
data:image/s3,"s3://crabby-images/41235/41235639f271a8418d3dcc3ee63f9fba60b1122a" alt=""