Вот мой gulpfile.js
var gulp = require('gulp');
var browserify = require('browserify');
var source = require("vinyl-source-stream");
var reactify = require("reactify");
var watchify = require('watchify');
var gutil = require('gulp-util');
var paths = {
scripts: ['src/jsx/index.jsx']
};
gulp.task('browserify', function(){
var bundler = watchify(browserify('./src/jsx/index.jsx', watchify.args));
bundler.transform(reactify);
bundler.on('update', rebundle);
function rebundle() {
return bundler.bundle()
// log errors if they happen
.on('error', gutil.log.bind(gutil, 'Browserify Error'))
.pipe(source('bundle.js'))
.pipe(gulp.dest('./public/js'));
}
return rebundle();
});
gulp.task('watch', function() {
gulp.watch(paths.scripts, ['browserify']);
});
Тогда мой вывод командной строки выглядит так:
$ gulp watch
[15:10:41] Using gulpfile ~/blizztrack/dashboard/gulpfile.js
[15:10:41] Starting 'watch'...
[15:10:41] Finished 'watch' after 9.95 ms
сохранить index.jsx
[15:10:45] Starting 'browserify'...
[15:10:51] Finished 'browserify' after 5.33 s
сохранить index.jsx во второй раз
[15:11:08] Starting 'browserify'...
[15:11:10] Finished 'browserify' after 2.02 s
сохранить index.jsx в третий раз
Нет вывода.
Кажется, это делает именно то, что я хочу, в первые два раза, а затем просто перестает смотреть. Может кто-то указать мне верное направление?
watchify
, иgulp.watch
? - person Ben   schedule 04.12.2014watchify
, он обрабатывает добавочные сборки браузера для вас. Таким образом, вам не нужно использоватьgulp.watch
, если вы используетеwatchify
. Я подозреваю, что они как-то конфликтуют. - person Ben   schedule 05.12.2014