Gulp手表仅执行一次

时间:2019-02-16 21:40:22

标签: sass gulp run-sequence

我知道新的gulp版本存在很多问题。我不得不更改gulpfile.js,现在运行它时,它只执行一次。我尝试在return函数上使用gulp.watch,但是它什么也没做。 这是我的代码:

'use strict';

var gulp = require('gulp');
var sass = require('gulp-sass');
var runSequence = require('run-sequence');
var iconfont = require('gulp-iconfont');
var async = require('async');
var consolidate = require('gulp-consolidate');
var sassLint = require('gulp-sass-lint');

gulp.task('sass', function(){
    return gulp.src('app/scss/**/*.scss')
        .pipe(sass())
        .pipe(gulp.dest('app/css'))
});

gulp.task('sass-lint', function () {
    return gulp.src('app/scss/**/*.s+(a|c)ss')
        .pipe(sassLint())
        .pipe(sassLint.format())
        .pipe(sassLint.failOnError())
});

gulp.task('watch', gulp.series('sass'), function (){
    gulp.watch('app/scss/**/*.scss', gulp.series(gulp.parallel('sass' , 'sass-lint' )));
});

gulp.task('build', function (callback) {
    runSequence(['sass'],
        callback
        )
});

gulp.task('iconfont', function(done){
    var iconStream = gulp.src(['app/images/svg/*.svg'])
      .pipe(iconfont({
        fontName: 'icons',
      }));
      async.parallel([
        function handleGlyphs(cb) {
            iconStream.on('glyphs', function(glyphs, options) {
                gulp.src('conf/_iconfont-template.scss')
                  .pipe(consolidate('lodash', {
                    glyphs: glyphs,
                    fontName: 'icons',
                    fontPath: '../fonts/',
                    className: 's'
                  }))
                  .pipe(gulp.dest('app/scss/utilities/'))
                  .on('finish', cb);
              });
            },
            function handleFonts (cb) {
                iconStream
                    .pipe(gulp.dest('app/fonts/'))
                    .on('finish', cb);
            }
          ], done);
});

这是我在终端机中得到的东西:

enter image description here

1 个答案:

答案 0 :(得分:1)

您的问题主要在这里:

// your version
gulp.task('watch', gulp.series('sass'), function (){

// should be:
gulp.task('watch', gulp.series('sass', function (done) {

gulp.task现在仅接受两个参数。

其他评论:

  1. “监视”任务的这一部分很奇怪:

    gulp.series(gulp.parallel('sass' , 'sass-lint' )));
    

gulp.series在那里什么也不做,大概是您想要的:

gulp.parallel('sass' , 'sass-lint' ));

带有'watch'回调的最终done任务,用于指示异步完成。

gulp.task('watch', gulp.series('sass', function (done){
    gulp.watch('app/scss/**/*.scss', gulp.parallel('sass' , 'sass-lint'));
    done();
}));
  1. 您不再需要run-sequence插件。您可以将'build'任务改为使用gulp.series