我想观看多个文件,当它们发生变化时,我想运行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。
构建任务在重新加载之前被触发,但它不会等到它完成。任何想法如何解决这个问题?
提前致谢!
答案 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']);
这样,它只会在一切都完成后重新加载。