0

我有一个简单的 gulp 脚本。流程是:

  1. 删除 dist 文件夹
  2. 将 .html 和 .css 文件移动到新的 dist 文件夹
  3. 编译 typescript 并将生成的 .js 移动到 dist 文件夹
  4. 最小化 .js
  5. 将 .js 和 .css 注入 .html

问题是,如果我首先删除 dist 文件夹,则注入仅适用于 .js 文件。但是,如果我跳过 dist 文件夹的清理,它会创建一个正确的 .html(因为 index.html 中存在 .js 和 .css)。有没有人遇到过这个问题?如果是这样,您是如何解决的?我猜它与流水线有关。

Gulp 版本:“^3.9.1”

var gulp = require('gulp');
var ts = require('gulp-typescript');
var minify = require('gulp-minify');
var inject = require('gulp-inject');
var del = require('del');

gulp.task('default', ['clean'], function () {
    gulp.start('scripts')
});

gulp.task('clean', function (cb) {
    del(['dist'], cb)
});

gulp.task('move', function () {
    console.log('-- gulp is running task "move"');
    gulp.src(['app/**/*.html', 'app/**/*.css'])
        .pipe(gulp.dest('dist'));
});

gulp.task('compile', ['move'], function () {
    console.log('-- gulp is running task "compile"');
    return gulp.src('app/**/*.ts')
        .pipe(ts({
            noImplicitAny: true,
            out: 'app.js'
        }))
        .pipe(gulp.dest('dist'));
});

gulp.task('compress', ['compile'], function () {
    console.log('-- gulp is running task "compress"');
    gulp.src('dist/**/*.js')
        .pipe(minify({
            ext: {
                src: '-debug.js',
                min: '.js'
            },
            noSource: true
        }))
        .pipe(gulp.dest('dist'))
});


gulp.task('scripts', ['compress'], function () {
    console.log('-- gulp is running task "scripts"');
    var target = gulp.src('dist/index.html');
    var sources = gulp.src(['dist/**/*.js', 'dist/**/*.css'], {read: false});
    return target.pipe(inject(sources, {relative: true}))
        .pipe(gulp.dest('dist'));
});
4

1 回答 1

1

您遇到了竞争条件,因为您没有在几个地方正确地发出异步完成信号:

del不接受回调cb,它返回一个Promise。您需要从任务中返回该 Promise:

gulp.task('clean', function () {
  return del(['dist']);
});

流也需要从您的任务中返回。你没有在你的movecompress任务中这样做,这(除其他外)意味着gulp-inject可能在所有.css文件都复制到dist/.

gulp.task('move', function () {
  console.log('-- gulp is running task "move"');
  return gulp.src(['app/**/*.html', 'app/**/*.css'])
    .pipe(gulp.dest('dist'));
})

gulp.task('compress', ['compile'], function () {
  console.log('-- gulp is running task "compress"');
  return gulp.src('dist/**/*.js')
    .pipe(minify({
        ext: {
            src: '-debug.js',
            min: '.js'
        },
        noSource: true
    }))
    .pipe(gulp.dest('dist'));
});
于 2016-06-08T11:38:05.837 回答