gulpでSassとSlimの変更をそれぞれ監視するgulpfile.jsの書き方を教えてください。
Sassのコンパイルはscssファイルが変更されたタイミングで、slimのコンパイルはslimファイルが変更されたタイミングで実行したいです。
node、gulp、gulp-sass、gulp-slimはすでにnpmでインストールしています。
gulpfile.jsの中身は一旦下記の通りにしています。
js
1// gulpプラグインの読み込み 2const gulp = require("gulp"); 3// Sassをコンパイルするプラグインの読み込み 4const sass = require("gulp-sass"); 5 6// style.scssの監視タスクを作成する 7gulp.task("default", function() { 8 // ★ style.scssファイルを監視 9 return gulp.watch(["scss/**/**/*.scss" , "slim/**/**/*.slim"], function() { 10 // style.scssの更新があった場合の処理 11 12 // style.scssファイルを取得 13 return ( 14 gulp 15 .src("scss/**/**/*.scss", { base: "scss" }) 16 // Sassのコンパイルを実行 17 .pipe( 18 sass({ 19 outputStyle: "expanded" 20 }) 21 // Sassのコンパイルエラーを表示 22 // (これがないと自動的に止まってしまう) 23 .on("error", sass.logError) 24 ) 25 // cssフォルダー以下に保存 26 .pipe(gulp.dest("css")) 27 ); 28 }); 29});
ディレクトリ構成は下記の通りです。(後で変更になるかもしれませんが)
/ │ gulpfile.js │ index.html │ package-lock.json │ package.json │ ├─css │ style.css ├─images │ ├─sass │ │ style.scss │ └─modules │ _header.scss │ _footer.scss ├─script └─slim index.slim
よろしくお願いいたします。
あなたの回答
tips
プレビュー