我创建了一个 gulp 任务,用于使用 browserify 捆绑模块,并且我正在使用 watchify 来监视更改。这是我的 watchify 任务:
gulp.task('watch:browserify', function () {
var opts = assign({}, watchify.args, {
entries: ['./js/app.js'],
debug: true,
basedir: './app/',
paths: ['./lib']
});
var b = watchify(browserify(opts));
b.on('update', function () {
bundle();
});
function bundle() {
gutil.log(gutil.colors.blue("Starting Browserify..."));
var time = Date.now();
return b.bundle()
.on('error', gutil.log.bind(gutil, gutil.colors.red('Browserify Error')))
.pipe(source('bundle.js'))
.pipe(buffer())
.pipe(sourcemaps.init({loadMaps: true}))
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest('app'))
.on('end', function () {
var duration = Date.now() - time;
gutil.log(gutil.colors.blue('Finished Browserify') + " (%dms)", duration);
})
}
bundle();
});
如果我编辑主 js 文件 (./js/app.js),则始终会检测到更改。但是当我编辑主文件需要的其他一些文件时,大约每隔一次(但并非总是)检测到更改。我在这里做错了吗?
这是完整的 Github 存储库,所以也许你会完全了解我是如何计划这个工作的