12

我创建了一个 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 存储库,所以也许你会完全了解我是如何计划这个工作的

4

2 回答 2

1

我遇到了同样的问题,我已经正确设置了@akarve 提到的所有内容。我回去了watchify: "^2.6.0",问题就解决了。然而,构建/检测时间有点慢 - 大约半秒。尽管如此,还是比偶尔(经常!)不让 watchify 检测到我的更改要好得多。

此处的相关讨论(也是我在其中找到关于 v2.6.0 的评论)- https://github.com/substack/watchify/issues/216#issuecomment-119285896

于 2017-07-18T12:26:20.040 回答
1

您的代码示例有两个问题。

首先,watch:browserify必须接受回调或返回流,否则可能会出现竞争条件,如此所述。因此,例如,您的任务中的最后一行可能是return bundle();.

其次,在使用 watchify 时,必须将cacheand选项传递给,如下所示并在此处指定。packageCachebrowserify()

    var b = browserify({ cache: {}, packageCache: {} });

最后,确保app.js实际上在其依赖链中的某个位置依赖于您正在编辑的其他文件。

于 2015-10-15T00:19:45.393 回答