これからはじめるGulp #9:Ruby版Sassが使えるgulp-ruby-sassへの乗り換え
はじめに
前回のこれからはじめるGulp(8):delモジュールとvinyl-pathsモジュールを使ったファイルの削除でタスクの同期とディレクトリ・ファイルの削除について勉強しました。今回はgulp-sassからRuby版のSassが使えるgulp-ruby-sassに乗り換えてみます。
gulp-sassとgulp-ruby-sassの違い
gulp-sassはnode-sassのwrapperでruby版のSassがなくても動作しコンパイルも早いようです。ただし、.sassだとコンパイルに問題もあるとか(回避策はある)。gulp-ruby-sassはRuby版のSassを使うのでコンパイルがやや遅いという点はありますが安心して利用できます。言うまでのことでもありませんがRuby版のSassを使うためこれからはじめるGulp(1):bundler, rbenv, nodebrewでGulp環境を作ってみるで紹介した通りRuby環境とGemのインストールが必要です。
Sassプラグインの入れ替え
インストール済みのgulp-sassをアンインストールしてgulp-ruby-sassをインストールします。
gulp-sassのアンインストール
$ sudo npm uninstall gulp-sass --save-dev Password: unbuild [email protected]
gulp-ruby-sassのインストール
$ sudo npm install gulp-ruby-sass --save-dev [email protected] node_modules/gulp-ruby-sass ├── [email protected] ├── [email protected] ├── [email protected] ├── [email protected] ├── [email protected] ([email protected], [email protected], [email protected], [email protected], [email protected]) ├── [email protected] ([email protected], [email protected], [email protected], [email protected]) └── [email protected] ([email protected], [email protected], [email protected], [email protected], [email protected])
gulp-ruby-sassのオプション指定
require('gulp-sass')をrequire('gulp-ruby-sass')に置き換えます。gulp-ruby-sassはオブジェクトsass({})でオプションを渡します。bundlerを使っている場合、bundleExecオプションを有効{ bundleExec: true }にします。bundleExecを省略できるようにしている場合はbundleExecオプションは不要です。
var gulp = require('gulp'); var sass = require('gulp-ruby-sass'); //<- var connect = require('gulp-connect'); var plumber = require('gulp-plumber'); var notify = require('gulp-notify'); var paths = { srcDir : 'src', prvDir : 'prv', dstDir : 'prd' } gulp.task('sass:prv', function(){ var srcGlob = paths.srcDir + '/assets/_scss/*.scss'; var dstGlob = paths.prvDir + '/assets/css'; var errorMessage = "Error: <%= error.message %>"; var sassOptions = { //bundleExec : true, style : 'nested' } gulp.src( srcGlob ) .pipe(plumber({ errorHandler: notify.onError( errorMessage ) })) .pipe(sass( sassOptions )) //<- .pipe(gulp.dest( dstGlob )) .pipe(connect.reload()); });
オプションの詳細はgulp-ruby-sassのAPIの項に載っています。
bourbonやneatを読み込む
bourbonやneatを読み込むにはSassオプションのrequireを使います。requireには配列で読み込むLibraryを指定します。
var gulp = require('gulp'); var sass = require('gulp-ruby-sass'); var connect = require('gulp-connect'); var plumber = require('gulp-plumber'); var notify = require('gulp-notify'); var paths = { srcDir : 'src', prvDir : 'prv', dstDir : 'prd' } gulp.task('sass:prv', function(){ var srcGlob = paths.srcDir + '/assets/_scss/*.scss'; var dstGlob = paths.prvDir + '/assets/css'; var errorMessage = "Error: <%= error.message %>"; var sassOptions = { style : 'nested', require : ['bourbon', 'neat'] //<- } gulp.src( srcGlob ) .pipe(plumber({ errorHandler: notify.onError( errorMessage ) })) .pipe(sass( sassOptions )) .pipe(gulp.dest( dstGlob )) .pipe(connect.reload()); });
これで、bourbonやneatが@import
して使えるようになります。
@import 'bourbon'; @import 'neat';
ちなみにboubonやneatをgulp-sassで使いたい場合はnode-bourbon、node-neatが使えるようです。
loadPathを指定して読み込む
bourbonプロジェクトにbittersというLibraryがあります。このLibraryはgulp-ruby-sassのrequireオプションには対応していないためパスを指定してロードするか$ bitters installで作られたファイルをインポートする方法があります。bundlerでインストールしたbittersであれば下記のようにloadPathを指定して読み込むことができます。
var sassOptions = { style : 'nested', require : ['bourbon', 'neat'], loadPath : ['vendor/bundle/ruby/2.1.0/gems/bitters-0.10.1/app/assets/stylesheets'] }
SCSSにインポートするには@import 'base'を指定します。 以上、gulp-ruby-sassの使い方でした。明日はgulp-connectからgulp-webserverへの移行を試してみたいと思います。