Gulp手表,等待任务

时间:2015-02-18 09:24:34

标签: javascript msbuild gulp browser-sync

我想观看多个文件,当它们发生变化时,我想运行MsBuild并在构建完成时使用BrowserSync重新加载。到目前为止,我有这个“观察者”:

gulp.watch([config.templatePath+'/**/*','!'+config.templatePath+'/assets/stylesheets/**/*'],['build']).on('change', function(file) {
    browsersync.reload(file);
});

这个构建任务:

gulp.task('build', function() {
    return gulp
        .src(config.projectFile)
        .pipe(msbuild({
            toolsVersion: 12.0
        }));
});

这很好用,但是在构建完成之前重新加载浏览器。首先我认为gulp-msbuild存在问题,但我忘记了return,请参阅:https://github.com/hoffi/gulp-msbuild/issues/8

构建任务在重新加载之前被触发,但它不会等到它完成。任何想法如何解决这个问题?

提前致谢!

1 个答案:

答案 0 :(得分:3)

你需要一个单独的任务,比如build_reload

gulp.task('build_reload', function() {
    return gulp
        .src(config.projectFile)
        .pipe(msbuild({
            toolsVersion: 12.0
        }))
        .on('end', function() {
            browsersync.reload();
        }));;
});

然后将watch任务更改为:

gulp.watch([config.templatePath + '/**/*', '!' + config.templatePath + '/assets/stylesheets/**/*'], ['build_reload']);
这样,它只会在一切都完成后重新加载。