gulpでPostCSSを使う方法

gulpのプラグインの中にはPostCSSというフレームワークを必要とするものもあります。
今回はgulpでPostCSSを使う方法についてまとめておきます。
PostCSS
PostCSSは、Node.js製のCSSを操作するプラグインの作成ができるフレームワークです。
PostCSS製のプラグインは有名なものが多く、
- 自動でベンダープレフィックスを付与してくれる「Autoprefixer」
- 次世代のCSSを、モダンな環境にも対応できるように書き換えてくれる「cssnext」
- CSSを圧縮してくれる「cssnano」
- Sassのような変数やextendが使えるようになる「PreCSS」
などがあります。
gulpでPostCSSをインストールする時は、PostCSS製のプラグインを使用する目的なのが一般的になります。
gulp-postcssのインストール
今回は自動でベンダープレフィックスを付与してくれるAutoprefixerを使用する事を想定してみます。
まず、gulpでPostCSSを使用する時はgulp-postcssというプラグインをが必要なので、それとAutoprefixerをインストールします。
$ npm install -D gulp
$ npm install -D gulp-postcss
$ npm install -D autoprefixer
gulp-postcssの使い方
gulp-postcssの使い方は簡単で、タスクの中で.pipe(postcss(プラグイン名とオプションの設定))を追加するだけです。
後のオプションは使うプラグインによって変わりますが、Autoprefixerの場合は下記のように記述して、対応するブラウザを指定しています。
const gulp = require('gulp');
postcss = require('gulp-postcss');
autoprefixer = require('autoprefixer');
gulp.task('css', () => {
return gulp.src('./src/css/*.css')
.pipe(postcss([
autoprefixer({
browsers: [
'last 2 versions',
'Explorer >= 10',
'iOS >= 9.0',
'Android >= 4.1']
})
]))
.pipe(gulp.dest('./dist/css'));
});Autoprefixerなど、PostCSS製だと単体では動かないプラグインもあって、その時にはgulp-postcssを入れる必要がある。とだけ覚えておけば良さそうです。

Nuxt.jsでコンポーネントを作成してコードの共通化を行う|Nuxt.jsの基本
Bracket Pair ColorizerでVisual Studio Codeの括弧を色分けして見やすくする
CSSだけで画像の比率を保ってトリミングできる「object-fit」
Post Snippetsを使ってWordPressでショートコードをの登録と管理をもっと楽に!!
gulp-sass 5の「does not have a default Sass compiler」エラーを解消する
JavaScriptのforEach内で「continue」や「break」のような動作をさせる方法
Vue.jsを使う人が最低限導入しておきたいVisual Studio Codeの拡張機能
Vue.jsで値段を表示するときに3桁ごとにカンマを入れる方法
HTTP/2が設定されているはずなのに、ブラウザ上でHTTP/1.1になってしまう場合はセキュリティソフトを確認
サーバーのアップロードファイルの最大容量の確認と変更方法
iTerm2で「Use System Window Restoration Setting」を設定しているとアラートが表示されて機能しない
Google Chromeのサイト内検索(カスタム検索)機能を別のプロファイルに移行する方法
iPadで入力モードを切り替えずに数字や記号をすばやく入力する方法
iPhoneやiPadでYouTubeの再生速度を3倍速や4倍速にする方法
Keynoteで有効にしているはずのフォントが表示されない現象
MacのKeynoteにハイライトされた状態でコードを貼り付ける方法
AirPodsで片耳を外しても再生が止まらないようにする方法
iTerm2でマウスやトラックパッドの操作を設定できる環境設定の「Pointer」タブ
DeepLで「インターネット接続に問題があります」と表示されて翻訳できないときに確認すること
Ulyssesの「第2のエディタ」表示を使って2つのシートを横並びに表示する
無料版でも高機能なランチャーアプリ「Raycast」の基本機能と環境設定
OnyXでターミナルを使わずにmacOSの詳細設定を行う
軽量で高速なターミナルエミュレーター「Ghostty」の設定方法
Eagleで実現するクリエイティブ素材の簡単管理
かゆいところに手が届く「Supercharge」でMac環境を便利にカスタマイズする
超軽量なコードエディタ 「Zed」をサブエディタとして活用する
Bartender 6で追加されたWidgets機能で自作メニューバーアイテムを簡単に作成する
Googleカレンダーを便利に活用するための小技集(祝日だけを表示・月末の繰り返しイベントを追加)
Obsidianを使った「自己流PKM」で行う知識トレーニング
テキストエディタ・ノートアプリ関連のショートカットキーをKeyboard Maestroで統一する