Gulp 4-任务未完成-Gulpfile.js Browsersync

时间:2018-10-16 00:33:11

标签: node.js sass gulp browser-sync

我对将旧的Gulp 3 Gulpfile更改为在Gulp 4中工作感到有些困惑。

我已经到了一切似乎都可以工作的地步,只是默认和服务任务没有在powershell中标记为已完成。

请问如何解锁代码并使其正确完成?

var gulp        = require('gulp');
var browserSync = require('browser-sync').create();
var sass        = require('gulp-sass');

// Compile sass into CSS & auto-inject into browsers
gulp.task('sass', function() {
    return gulp.src(['node_modules/bootstrap/scss/bootstrap.scss', 'src/scss/*.scss'])
        .pipe(sass())
        .pipe(gulp.dest("src/css"))
        .pipe(browserSync.stream());
});

// Move the javascript files into our /src/js folder
gulp.task('js', function() {
    return gulp.src(['node_modules/bootstrap/dist/js/bootstrap.min.js', 'node_modules/jquery/dist/jquery.min.js', 'node_modules/popper.js/dist/umd/popper.min.js'])
        .pipe(gulp.dest("src/js"))
        .pipe(browserSync.stream());
});

// Static Server + watching scss/html files
gulp.task('serve', gulp.series('sass', function() {

    browserSync.init({
        server: "./src"  
    });

    gulp.watch(['node_modules/bootstrap/scss/bootstrap.scss', 'src/scss/*.scss'], gulp.series('sass'));
    gulp.watch("src/*.html").on('change', browserSync.reload);
}));

gulp.task('default', gulp.parallel('js', 'serve'));

1 个答案:

答案 0 :(得分:1)

您的serve系列中的第二项任务不返回任何内容,而gulp对此不了解。一个任务可以返回一个流或一个Promise-或者它必须调用callback参数来表示完成,例如:

gulp.task('serve', gulp.series('sass', function(cb) {
    // Your js task code here
    cb()
}))

阅读最新的gulp4 documentation,它将为您提供帮助。