手数をかけずに分割されたCSSをまとめてみた
🚀 はじめに
この記事では、手数をかけずに分割された CSS をどうやってまとめるかを検討した際に PostCSS のみで実現することができたのでそのときにやったことなどをまとめます。
PostCSS の説明自体は端折らせていただきます。
完了の定義
- まとめられた CSS の中身は、import のリストではなくコードがすべて展開されている
- ミニファイされている
- 開発時に便利なように gulp や Webpack を使ったときのように変更を監視して自動的に処理が走る
前提
- ローカル環境で、Node.js が動く
パッケージをインストールして早速動かしてみる
npm init
して package.jsonを作成します。
続いて、postcss-cli をインストールします。
npm install postcss-cli --save-dev
ひとまず、postcss のインストールは完了です。
テスト用のCSSを用意します。
@import "./modules/hoge";
@import "./modules/fuga";
body {
color: red;
text-align: center;
background-color: blue;
margin: 100px;
padding: 100px;
}
body.fuga {
color: blue;
text-align: center;
background-color: blue;
}
こんな構成です。
では早速 PostCSS を走らせてみます。
node_modules/.bin/postcss src/app.css -o out/app.min.css
結果がこちら。
@import "./modules/hoge";
@import "./modules/fuga";
これは全然意図したものではありません。
まとめたと言えばそうですが、リクエストがそれぞれ発生するので良くなさそうです。
必要そうなプラグインを入れる
npm install autoprefixer cssnano postcss-import --save-dev
設定ファイルを用意します。
module.exports = {
plugins: [
require('autoprefixer')(),
require('cssnano')({
preset: 'default',
}),
require('postcss-import')()
]
}
これで、もう一度 PostCSS を走らせてみます。
node_modules/.bin/postcss src/app.css -o out/app.min.css
結果がこちら。
body.hoge{color:blue}body,body.hoge{background-color:blue;text-align:center}body{color:red;margin:100px;padding:100px}
良さげですね。@import ではなくコードがちゃんと展開されています。cssnano
によって ミニファイもされてそうです。autoprefixer
については未検証で申し訳ないです🙇
npm スクリプトにして監視する
"scripts": {
"css/postcss": "postcss src/app.css -o out/app.min.css",
"watch": "npm run css/postcss -- --watch"
},
こんなかんじにしました。早速実行してみます。
npm run watch
> postcss-sandbox@1.0.0 watch
> npm run css/postcss -- --watch
> postcss-sandbox@1.0.0 css/postcss
> postcss src/app.css -o out/app.min.css "--watch"
待受状態になってそうです。
hoge.css と fuga.css をそれぞれ編集してみます。
(編集内容は省きます)すると、以下のように更新されました。
body.hoge{background-attachment:fixed;background-color:blue;color:blue;text-align:center}header{transition-property:100%}body{background-color:blue;margin:100px;padding:100px;text-align:center}body,footer{color:red}
ログとか何も出ないので動いてるかどうか判断しにくいのですが、ファイルを確認すれば更新されていることがわかります。
これで gulp や Webpack を使ったときのように変更を監視して自動的に処理が走る
が実現できました。
最後に
なかなか生の CSS を書く機会は減ってきていると思いますが、弊社内で数々の分割された CSS をまとめるにはどうすべきかという話が出てきた際に今回のような検証を実施しました。
最後までお読みいただきありがとうございました🙇
私たち BABY JOB は、子育てを取り巻く社会のあり方を変え、「すべての人が子育てを楽しいと思える社会」の実現を目指すスタートアップ企業です。圧倒的なぬくもりと当事者意識をもって、子どもと向き合う時間、そして心のゆとりが生まれるサービスを創出します。baby-job.co.jp/
Discussion