Gulp jekyll цикл восстановления синхронизации браузера

Я использую скрипт Gulp в своем проекте Jekyll вместе с синхронизацией браузера и некоторыми другими плагинами (для минимизации / объединения JS / Sass и минимизации изображений и svg).

Начиная с нескольких дней назад (я не уверен, что вызвало это, использование моих старых скриптов gulp не помогает), это вызывает цикл из 2-15 перезагрузок каждый раз, когда я сохраняю файл HTML или JS.

Это возвращает следующее в терминале:

[00:51:47] Finished 'jekyll-build' after 850 ms
[00:51:47] Starting 'jekyll-rebuild'...
[BS] Reloading Browsers...
[00:51:47] Finished 'jekyll-rebuild' after 241 μs
[00:51:47] Starting 'jekyll-build'...
      Generating... 
                    done in 0.188 seconds.
 Auto-regeneration: disabled. Use --watch to enable.
[00:51:48] Finished 'jekyll-build' after 881 ms
[00:51:48] Starting 'jekyll-rebuild'...
[BS] Reloading Browsers...
[00:51:48] Finished 'jekyll-rebuild' after 480 μs
[00:51:48] Starting 'jekyll-build'...
      Generating... 
                    done in 0.251 seconds.
 Auto-regeneration: disabled. Use --watch to enable.
[00:51:49] Finished 'jekyll-build' after 826 ms
[00:51:49] Starting 'jekyll-rebuild'...
[BS] Reloading Browsers...
[00:51:49] Finished 'jekyll-rebuild' after 942 μs

Мой Gulpfile выглядит следующим образом. Извините, что вставил сюда так много кода.

/**
 * Build the Jekyll Site
 */
gulp.task('jekyll-build', function (done) {
    browserSync.notify(messages.jekyllBuild);
    return cp.spawn('jekyll', ['build'], {stdio: 'inherit'})
        .on('close', done);
});

/**
 * Rebuild Jekyll & do page reload
 */
gulp.task('jekyll-rebuild', ['jekyll-build'], function () {
    browserSync.reload();
});

/**
 * Wait for jekyll-build, then launch the Server
 */
gulp.task('browser-sync', ['sass', 'jekyll-build', 'jekyll-rebuild', 'imagemin', 'svgmin'], function() {
    browserSync({
        server: {
            baseDir: '_site'
        }
    });
});

/**
 * Compile files from _scss into both _site/css (for live injecting) and site (for future jekyll builds)
 */
gulp.task('sass', function () {
    return gulp.src('_scss/main.scss')
        .pipe(sass({
            includePaths: ['scss'],
            onError: browserSync.notify
        }))
        .pipe(prefix(['last 15 versions', '> 1%', 'ie 8', 'ie 7'], { cascade: true }))
        .pipe(gulp.dest('_site/css'))
        .pipe(browserSync.reload({stream:true}))
        .pipe(gulp.dest('css'))
        .pipe(rename({
            extname: ".min.css"
        }))
        .pipe(uglifycss())
        .pipe(gulp.dest('css'))
        .pipe(gulp.dest('_site/css'));
});

/** optimize images **/

gulp.task('imagemin', function() {
    return gulp.src('assets/img/*')
        .pipe(imagemin({
            progressive: true,
            svgoPlugins: [{removeViewBox: false}],
            use: [pngquant()]
        }))
        .pipe(gulp.dest('./_site/assets/img'))
        .pipe(browserSync.reload({stream:true}));
});

gulp.task('svgmin', function() {
    return gulp.src('assets/svg/*.svg')
        .pipe(svgmin())
        .pipe(gulp.dest('./_site/assets/svg'));
});

gulp.task('scripts', function() {
    return gulp.src([
        '***scripts***' //removed for readability
        ])
        .pipe(include())
        .pipe(plumber({
            errorHandler: function(err){
                notify('JS compile error: ' + err);
            }
        }))
        .pipe(concat('main.js'))
        .pipe(gulp.dest('javascript'))
        .pipe(rename({
            extname: ".min.js"
        }))
        .pipe(uglify())
        .pipe(gulp.dest('javascript'))
        .pipe(browserSync.reload({stream:true}))
        .pipe(notify('JS Compiled'));
});

/** Lint JS **/

gulp.task('lint', function() {
    return gulp.src('javascript/app/*.js')
        .pipe(jshint())
        .pipe(jshint.reporter('default'));
});

/**
 * Watch scss files for changes & recompile
 * Watch html/md files, run jekyll & reload BrowserSync
 */
gulp.task('watch', function () {
    gulp.watch('_scss/**/**/**/*.scss', ['sass']);
    gulp.watch('assets/img/*', ['imagemin']);
    gulp.watch('assets/svg/*', ['svgmin']);
    gulp.watch('javascript/app/*.js', ['lint', 'scripts']);
    gulp.watch(['*.html', '**/*.html', 'javascript/main.js', '_layouts/*.html', '_includes/**/**/*.html'], ['jekyll-rebuild']);
});

/**
 * Default task, running just `gulp` will compile the sass,
 * compile the jekyll site, launch BrowserSync & watch files.
 */
gulp.task('default', ['browser-sync', 'watch']);

Кто-нибудь видит что-то, что может быть причиной этого?


person Sanderfish    schedule 04.03.2016    source источник


Ответы (1)


Я думаю, что линия в ваших часах слишком широкая: gulp.watch(['*.html', '**/*.html', 'javascript/main.js', '_layouts/*.html', '_includes/**/**/*.html'], ['jekyll-rebuild']);

Второй - '**/*.html' я думаю, что он видит любые подпапки, которые включают папку _site, поэтому он видит все изменения там и зацикливается. Вы меняете файл, он регенерируется, папка _site сбрасывается, он это видит, регенерируется и т.д. и т.п.

изменить в папку исключенного _site
Если у вас много подпапок и вы хотите включить их в **/*.html, попробуйте исключить каталог _site, добавив '!_site/**/*' в список.

Кроме того, имейте в виду, что вы указываете .html, который не будет подхватывать файлы уценки.

Работа над этим вопросом привела к следующему - думаю, это будут мои новые часы (у меня нет причин не смотреть все файлы, другим это может не понравиться):

gulp.watch(['**/*.*', '!_site/**/*', '!node_modules/**/*','!.sass-cache/**/*' ], ['jekyll-rebuild']);

первая часть вроде все смотрит, вторая часть исключает папку сайта и все в ней, потом тоже самое для node_modules и .sass-cache. Я имел:

gulp.watch(['./*', '_layouts/*', '_videos/*', 'order-online/*', '_includes/*', '_posts/*', '_sass/*', 'css/*', 'services/*', '_data/*' ], ['jekyll-rebuild']);
person Ron    schedule 05.03.2016
comment
Спасибо за Ваш ответ. Я думаю, ты двигаешь меня в правильном направлении. Как убедиться, что папка _site не включена? У меня довольно много подпапок, которые содержат отдельные файлы index.html. Я мог бы, конечно, указать папки отдельно, но было бы чище исключить _site. - person Sanderfish; 05.03.2016
comment
Я знаю, что указывал на все мои папки отдельно вместо использования **/*.html, и это действительно прекращает цикл! Если бы вы знали, как исключить папку _site, было бы здорово, иначе я приму ваш ответ завтра. - person Sanderfish; 05.03.2016
comment
попробуйте добавить перед _site ! чтобы исключить эту подпапку. Я отредактирую свой ответ, чтобы включить это. - person Ron; 06.03.2016