GulpでSassコンパイルを行う際に使用するコンパイラをnode-sass(LibSass)からDart Sass への移行する際の流れを記述します。
Dart Sassへの移行の必要性については本内容では省きます。以下参考ページをご覧ください。
流れ
Dart Sassとfibersのインストール
gulpfile.jsで使用するコンパイラを変更
既存SassファイルをDart Sassの仕様へ移行
インストール
必要なパッケージをインストールします。
yarn add -D cross-env fibers gulp gulp-sass sass
gulpfile.jsで使用するコンパイラをDart Sassに指定する
必要最小構成で記述したgulpfile.js
の例が以下です。
const Fiber = require ( ' fibers ' )
const gulp = require ( ' gulp ' )
const sass = require ( ' gulp-sass ' )
sass.compiler = require ( ' sass ' ) // ここでコンパイラの指定をDart Sass(npm上のパッケージ名)に指定する
" css " : " dist/assets/css/ "
const scssCompile = () => {
. src (setting.io.input.css + ' **/*.scss ' , { sourcemaps : true })
. pipe ( sass ({fiber : Fiber, outputStyle : ' compressed ' }). on ( ' error ' , sass.logError))
. pipe (gulp. dest (setting.io.output.css, { sourcemaps : ' /maps ' }))
const watch = () => gulp. watch (setting.io.input.css + ' **/*.scss ' , scssCompile)
exports .development = scssCompile
" watch " : " cross-env NODE_ENV=development gulp " ,
" development " : " cross-env NODE_ENV=development gulp development "
ポイントはsass.compiler = require('sass')
と記述している箇所でコンパイラの指定を行っている点です。以下のようにコンパイラ自体の切り替えは簡単に行えます。
コンパイラにDart Sass を使用する場合はrequire('sass')
と指定
コンパイラにnode-sass を使用する場合はnode-sassを別途インストールしrequire('node-sass')
と指定
登場するfibers
はコンパイラの高速化のために用いられます。
To avoid this performance hit, render() can use the fibers package to call asynchronous importers from the synchronous code path. To enable this, pass the Fiber class to the fiber option:
その他sass()
に渡すオプションはDart Sass公式ページ より確認し必要に応じて付与してください。
諸々含めた場合のgulpfile.js
上記は最小構成の記述でしたが実際に使用する場合は各種パッケージも必要になります。諸々を含めたサンプルを以下になります。
const autoprefixer = require ( ' autoprefixer ' )
const cssnano = require ( ' cssnano ' )
const cssDeclarationSorter = require ( ' css-declaration-sorter ' )
const Fiber = require ( ' fibers ' )
const gulp = require ( ' gulp ' )
const mqpacker = require ( ' css-mqpacker ' )
const postcss = require ( ' gulp-postcss ' )
const sass = require ( ' gulp-sass ' )
sass.compiler = require ( ' sass ' )
" css " : " dist/assets/css/ "
const scssCompile = () => {
. src (setting.io.input.css + ' **/*.scss ' , { sourcemaps : true })
. pipe ( sass ({fiber : Fiber, outputStyle : ' compressed ' }). on ( ' error ' , sass.logError))
cssnano ({ autoprefixer : false }),
cssDeclarationSorter ({ order : ' smacss ' })
. pipe (gulp. dest (setting.io.output.css, { sourcemaps : ' /maps ' }))
const scssProductionCompile = () => {
. src (setting.io.input.css + ' **/*.scss ' )
. pipe ( sass ({fiber : Fiber, outputStyle : ' compressed ' }). on ( ' error ' , sass.logError))
cssnano ({ autoprefixer : false }),
cssDeclarationSorter ({ order : ' smacss ' })
. pipe (gulp. dest (setting.io.output.css))
const watch = () => gulp. watch (setting.io.input.css + ' **/*.scss ' , scssCompile)
exports .development = scssCompile
exports .production = scssProductionCompile
" watch " : " cross-env NODE_ENV=development gulp " ,
" development " : " cross-env NODE_ENV=development gulp development " ,
" production " : " cross-env NODE_ENV=production gulp production "
" autoprefixer " : " ^9.0.0 " ,
" css-declaration-sorter " : " ^5.1.2 " ,
" css-mqpacker " : " ^7.0.0 " ,
" gulp-postcss " : " ^9.0.0 " ,
既存SassファイルをDart Sassの仕様へ移行
Dart Sassとnode-sassの記述にはいくつかの違いがありますが、大きな違いとして@import
を廃止し@use
への移行が挙げられます。
現在は互換性が保たれているため使用できますが、完全廃止が明言されているためDart Sassに切り替えるタイミングでこれら記述の変更も行うべき作業になります。
具体的には以下のように@use
に変更していく作業が発生します。
また@import
の時とは異なり変数や関数のスコープ範囲が読み込まれたファイル内に限定されるため、単純に@use
に記述を変更するだけでは移行できない場合も往々にして出てきます。
たとえば以下のように大本のstyle.css
でFoundation/variables.scss
とProjects/top.scss
をimportした時、Projects/top.scss
ではFoundation/variables.scss
内の変数を使用する事はできません。
@import " scss/Foundation/variables " ;
@import " scss/Projects/top " ;
$fontFamily : " Noto Sans CJK JP " , " Noto Sans JP " , sans-serif ;
font-family : $fontFamily ; // Error: Undefined variable.
Dart Sassでは変数を使用したいsassファイル毎に@use
を行い、名前空間はas節で指定します。ES6などでのモジュール呼び出しの形をイメージすると分かりやすいです。
@use " scss/Foundation/variables " as * ;
@use " scss/Foundation/mixin " as mx ;
background-color : $color--blue ;
background-color : $color--red ;
ビルトインモジュールの使用の際も事前に@use
で宣言をする必要があります。たとえばmap-get
を使用する場合は以下のようにします。
margin : map-get ( $map , $key );
node_modules
配下よりcssファイルを読み込む際はチルダで指定することは出来ず、階層に合わせたパスの指定が必要です。
@use " ~ress/ress.css " ; // NG
@use " ../../../node_modules/ress/ress.css " ; // OK
その他にもDart Sass特有の記述や機能がありそれらを用い移行する作業が発生します。
よりSassを活用したプロジェクトだと移行に必要な作業は多く、また簡素なプロジェクトであれば@use
に書き換えるレベルで対応できたりとSassの活用度(熟練度)に応じて移行コストが変わります。
実際に移行する際はSassを@importから@useに置き換えるための手引き などのドキュメントを確認しつつ、一気に移行するのが難しい場合はスコープを区切って徐々に移行していくといいでしょう。
ちなみにnode-sass(LibSass)はすでにDeprecatedアナウンスがされていますが、メンテナンスは引き続き行われるとの事です。
Michael Mifsud, the lead maintainer of LibSass and Node Sass, has affirmed that he plans to continue maintenance on the same level as the past few years. This means that although there will be no more features added (and as such LibSass will slowly drift further and further out of compatibility with the latest CSS and Sass syntax), there will continue to be maintenance releases indefinitely.
引用:https://sass-lang.com/blog/libsass-is-deprecateda
移行ツール