質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
gulp

gulpは、Node.jsをベースとしたタスク自動化ツールの一つ。ストリームでファイルを処理することが特徴です。CSSプリプロセッサの使用時のコンパイルや、CSS・JavaScriptファイルの圧縮・結合などを自動的に行うことができます。

Q&A

解決済

1回答

1692閲覧

gulp の watch 制御

poliphilus

総合スコア150

gulp

gulpは、Node.jsをベースとしたタスク自動化ツールの一つ。ストリームでファイルを処理することが特徴です。CSSプリプロセッサの使用時のコンパイルや、CSS・JavaScriptファイルの圧縮・結合などを自動的に行うことができます。

0グッド

0クリップ

投稿2017/06/20 07:05

gulp で imagemin を使用して画像を圧縮しているのですが、
ひとつ画像が増える(もしくはアップデートする)と
対象フォルダの全画像に対して圧縮をかけてしまうので、
画像が増えると時間がかかりすぎてしまいます。
ですので、吐き出すフォルダ内のファイルのタイムスタンプをチェックし、
古い場合のみ圧縮をする事は可能でしょうか。
もしくは、圧縮し終わったら元ファイルを削除する、でも構いません
(これでも重複作業は避けられます)。

現在は以下のようにしています。よろしくお願いします。

JavaScript

1var gulp = require('gulp'); 2var watch = require('gulp-watch'); 3var imagemin = require('gulp-imagemin'); 4 5gulp.task('imagemin', () => { 6 return gulp.src(['src/**/*.jpg', 'src/**/*.png']) 7 .pipe(imagemin()) 8 .pipe(gulp.dest('www')); 9}); 10 11gulp.task('watch', () => { 12 watch(['src/**/*.jpg', 'src/**/*.png'], () => { 13 return gulp.start(['imagemin']); 14 }); 15});

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

以下な感じでどうでしょうか?

javascript

1var IN_DIR = 'src'; 2var OUT_DIR = 'www'; 3 4var gulp = require('gulp'); 5var imagemin = require('gulp-imagemin'); 6var path = require('path'); 7var watch = require('gulp-watch'); 8 9gulp.task('watch', () => { 10 watch([`${IN_DIR}/**/*.jpg`, `${IN_DIR}/**/*.png`], (e) => { 11 // console.log('処理開始'); 12 var PATH = path.parse(e.path); 13 var distDir = __dirname + PATH.dir.replace(__dirname, '').replace(IN_DIR, OUT_DIR); 14 15 return gulp.src(e.path) 16 .pipe(imagemin()) 17 .pipe(gulp.dest(distDir)); 18 }); 19});

投稿2017/06/20 09:28

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

poliphilus

2017/06/21 08:14

すみません、これは何をしてるのでしょう…特に処理として変わらない気がしますが。
退会済みユーザー

退会済みユーザー

2017/06/23 00:59 編集

コメントを見落としていました。 watchのコールバックには更新されたファイルの情報が返ってくるので(上記の場合変数e)、 それをこから更新されたファイルのみをimageminに渡して、wwwディレクトリ下に書き出すようにしたものとなります。
poliphilus

2017/06/23 03:08

…なんだか理解できませんが(笑)、やってみたらうまく動作しました。あとでトレースしてみます。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問