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を入れる必要がある。とだけ覚えておけば良さそうです。

SourceTreeを開くと「’git status’ failed with code 69:’」というポップアップが出てくる場合の解決方法
Visual Studio Codeのファイル横に表示されるファイルアイコンのテーマまとめ
手軽にコーディングの勉強ができるCodePenをもっと便利に使うための設定
JavaScriptのテンプレートリテラル内で条件分岐を行う方法
スクロールしてもテーブルヘッダーが追尾するテーブルの作り方
WordPressの常時SSL化で、下層ページのhttpからhttpsへのリダイレクトがうまくいかない場合に確認すること
iCLUSTA+でWordPressのアップロード容量を上げたいときのメモ
Visual Studio Codeで「.html」拡張子以外のファイルでもEmmetを使えるようにする
「EWWW Image Optimizer」を使ってWordPressをWebPに対応する方法
iTerm2で「Use System Window Restoration Setting」を設定しているとアラートが表示されて機能しない
Google Chromeのサイト内検索(カスタム検索)機能を別のプロファイルに移行する方法
iPadで入力モードを切り替えずに数字や記号をすばやく入力する方法
iPhoneやiPadでYouTubeの再生速度を3倍速や4倍速にする方法
Keynoteで有効にしているはずのフォントが表示されない現象
MacのKeynoteにハイライトされた状態でコードを貼り付ける方法
AirPodsで片耳を外しても再生が止まらないようにする方法
iTerm2でマウスやトラックパッドの操作を設定できる環境設定の「Pointer」タブ
DeepLで「インターネット接続に問題があります」と表示されて翻訳できないときに確認すること
Ulyssesの「第2のエディタ」表示を使って2つのシートを横並びに表示する
Neovimを使い始める最初の一歩として便利な「LazyVim」
ウェブサイトをmacOSアプリとしてラッピングする「Unite Pro」
Keyboard Maestroの「Macro Debugger」で複雑なマクロのデバッグを行う方法
無料版でも高機能なランチャーアプリ「Raycast」の基本機能と環境設定
OnyXでターミナルを使わずにmacOSの詳細設定を行う
軽量で高速なターミナルエミュレーター「Ghostty」の設定方法
Eagleで実現するクリエイティブ素材の簡単管理
かゆいところに手が届く「Supercharge」でMac環境を便利にカスタマイズする
超軽量なコードエディタ 「Zed」をサブエディタとして活用する
Bartender 6で追加されたWidgets機能で自作メニューバーアイテムを簡単に作成する