目次
エンジニアがいい感じにフロントエンド開発を爆速化できる環境構築の手順
LIGさんの記事。個人的にはこれよりもシンプルなものが欲しくてあれこれ試しました。 GulpもBowerも使いません。あとユニットテストもするほどの規模ではないプロジェクトを想定。
webpackはJavaScriptのrequireを使いたくて利用。
SassのコンパイルやらCSSをrequireするのやらはどうも違和感がぬぐえなくてnpm使ってます。
しかしフロントエンドの開発環境も変遷が激しくちょっと大きめのプロジェクトに没頭などしようものなら浦島太郎ですってことになるのでちょいちょいのアップデートが重要だなと。
必要なものあるかどうか確認
1 | node -v |
まずはお決まりのNode.js入ってるか確認。
1 | npm -v |
npm(Node.jsのパッケージマネージャー)も入ってるか確認。
1 | webpack -v |
webpackも入っているか確認。
もし入ってなかったら
1 | npm install -g webpack |
-gオプションはGlobalオプションのこと。
ファイル・フォルダ構成
1 | git clone https://github.com/shigekitakeguchi/npm-webpack-sass.git |
https://github.com/shigekitakeguchi/npm-webpack-sass
GitHubから落として使ってください。
カスタマイズなりなんなりして。
1 | cd npm-webpack-sass |
落としたフォルダ内に移動する。その前に
1 | ├── README.md |
ファイル・フォルダ構成はこんな感じ。README.mdは不要。
1 | npm install |
これで必要なパッケージがインストールされるはず。
package.json
1 | { |
中身はこんな感じ。
パッケージの説明
落としてきたpackage.jsonからインストールすればいいんですがそれぞれのパッケージの説明を。
1 | npm install --save-dev concurrently |
https://github.com/kimmobrunfeldt/concurrently
concurrentlyは複数のコマンド実行できるようにするため。具体的に何をしているかは後ほど説明。
1 | npm install --save-dev lite-server |
https://github.com/johnpapa/lite-server
webpackにもwebpack dev serverというのがあるみたいだけどlite-serverのがシンプルで良さそうなので使ってみた。
ただし設定ファイルは必要でした。
1 | npm install --save-dev node-sass |
https://github.com/sass/node-sass
node-sassでSassのコンパイル。全体的にNode.jsなのでSassのコンパイルだけRubyでなくてもいいだろうということで導入。
1 | npm install --save-dev nodemon |
https://github.com/remy/nodemon
scssを監視してコマンドを実行する。具体的に何をしているかは後ほど説明。
1 | npm install --save-dev webpack |
https://github.com/webpack/webpack
webpack。もうすでに何をするツールなのか説明しがたいくらい機能がある。
静的なファイル(JavaScript系、CSS系、画像ファイル)の依存関係を解決するためのビルドツールってことなんだけど、ここでははJavaScriptだけを扱うようにしている。
package.jsonの中のscriptsで何をしているか
1 | "scripts": { |
1 | npm start |
このコマンドでlite-serverを立ち上げwebpackでwatchを行いcssの変更を監視するようにしている。
1 | "start": "concurrently \"npm run lite\" \"npm run webpack\" \"npm run watch-css\"" |
scriptsの中にあるstartがこれにあたる。
1 | npm run lite |
1 | npm run webpack |
1 | npm run watch-css |
これらのコマンドはそれぞれ独立したコマンドですが、最初にちょっと触れたがconcurrentlyにダブルクオーテーションでくくってスペースで区切って引数で渡せば並行して実行することになる。便利。
1 | "webpack": "webpack -w", |
これはwebpackのwatch(監視)を走らせている。こちらも後ほど触れるがwebpack.config.jsonで記述されたことをもとに監視している。
1 | "lite": "lite-server", |
lite-serverを立ち上げている。bs-config.jsonに設定ないようを記述している(こちらも後ほど触れる)。
1 | "build-css": "node-sass ./src/scss/app.scss ./app/styles/app.css --output-style compressed", |
Sass(Scss)をnode-sassを使ってコンパイルしている。
- ./src/scss/app.scssはコンパイルする前のファイル。css(個人的にはScss記法だけど)の記述はこれにする。
- ./app/styles/app.cssはコンパイル後のファイル。
- –output-style compressedはコンパイル後のファイルを圧縮する設定。他にはnested、expanded(これが一般的に人が書くのに近いスタイル)、compactが使える。これはガイドラインや好みで。
Sass Documentation(output_style)
1 | "watch-css": "nodemon -e scss -x \"npm run build-css\"", |
nodemonを使ってscssファイルを監視し、変更があれば「npm run build-css」を走らせるという設定。
「-e scss」ってのがscssを監視するというオプション。-xは「npm run build-css」を実行するためのオプションになる。
webpack.config.json
1 | var webpack = require("webpack"); |
webpackの設定はいたってシンプル。entryにもとファイル(複数ある場合は配列で持たせる)。outputに出力される設定を記述。今回はbundle.jsっていう一般的によく使われているらしい名称のまま。
素のままのファイルだともうファイルがでかくてあれなんでUglifyJsPluginで圧縮・最適化。
bs-config.json
1 | { |
lite-serverの設定はドキュメントルートをappの直下にしたかったのと監視対象のファイル(html、css、js)が変更されたらリロードしてinjectChangesというBrowsersyncを動すため。
個人的にはThree.jsやp5.jsを気軽に試したいときの環境をさくっと用意したかったために用意した感じになる。
あとReact.jsを使うためにそもそもwebpackをはじめたのでReact.js版も公開します。
まだwebpackをはじめて数日とかという状態なので間違えや指摘をいただけると助かります。