Browser-sync не обновляет страницу после изменений с помощью Gulp

Я новичок в Gulp, и я хотел использовать его автоматическую компиляцию scss и синхронизацию браузера. Но я не могу заставить его работать.

Я раздели все, чтобы оставить только содержимое примера на веб-сайте Browsersync:

http://www.browsersync.io/docs/gulp/#gulp-sass-css

var gulp        = require('gulp');
var browserSync = require('browser-sync').create();
var sass        = require('gulp-sass');

// Static Server + watching scss/html files
gulp.task('serve', ['sass'], function() {

    browserSync.init({
        server: "./app"
    });

    gulp.watch("app/scss/*.scss", ['sass']);
    gulp.watch("app/*.html").on('change', browserSync.reload);
});

// Compile sass into CSS & auto-inject into browsers
gulp.task('sass', function() {
    return gulp.src("app/scss/*.scss")
        .pipe(sass())
        .pipe(gulp.dest("app/css"))
        .pipe(browserSync.stream());
});

gulp.task('default', ['serve']);

Я могу вызвать Gulp. Сайт отображается, и я получаю сообщение от Browsersync. Когда я изменяю HTML, страница перезагружается. Когда я изменяю scss, я вижу это:

[BS] 1 file changed (test.css)
[15:59:13] Finished 'sass' after 18 ms

но я должен перезагрузить вручную. Что мне не хватает?

Ответы

Ответ 1

Вы можете просто вставлять изменения вместо того, чтобы принудительно использовать полное обновление браузера в компиляции SASS, если хотите.

browserSync.init({
    injectChanges: true,
    server: "./app"
});

gulp.task('sass', function() {
    return gulp.src("app/scss/*.scss")
        .pipe(sass())
        .pipe(gulp.dest("app/css"))
        .pipe(browserSync.stream({match: '**/*.css'}));
});

Ответ 2

Это потому, что вы вызываете browserSync.reload на часах html, а не на часах scss.

Попробуйте следующее:

gulp.watch("app/scss/*.scss", ['sass']).on('change', browserSync.reload);
gulp.watch("app/*.html").on('change', browserSync.reload);

Ответ 3

Это то, что я использую, и он отлично работает в sass или любых других файлах

gulp.task('browser-sync', function () {
   var files = [
      '*.html',
      'css/**/*.css',
      'js/**/*.js',
      'sass/**/*.scss'
   ];

   browserSync.init(files, {
      server: {
         baseDir: './'
      }
   });
});

Ответ 4

У меня также возникла аналогичная проблема, когда я был новичком в использовании браузера-синхронизации, в командной строке говорилось "перезагрузка браузеров", но браузер не был обновлен вообще, проблема в том, что я не включил тег body в свой HTML страница, где браузер-синхронизация может ввести script для своей функциональности, убедитесь, что на вашей HTML-странице есть тег тела.

Ответ 5

Включите эту же проблему, пытаясь перезагрузить файлы php и js и файлы потока css. Мне удалось использовать поток только с помощью метода pipe, что имеет смысл. Во всяком случае, вот что сработало для меня:

gulp.watch(['./**/*.css']).on('change', function (e) {
    return gulp.src( e.path )
        .pipe( browserSync.stream() );
});

Но, я действительно предпочитаю @pixie ответ изменен:

gulp.task('default', function() {
    var files = [
            './**/*'
        ];
    browserSync.init({
        files : files,
        proxy : 'localhost',
        watchOptions : {
            ignored : 'node_modules/*',
            ignoreInitial : true
        }
    });
});

Ответ 6

Я включаю это в свой html, прямо под тегом body. Он работает.

<script type='text/javascript' id="__bs_script__">//<![CDATA[
document.write("<script async src='http://HOST:3000/browser-sync/browser-sync-client.2.11.1.js'><\/script>".replace("HOST", location.hostname));//]]>
</script>

Ответ 7

У меня тоже была такая же проблема. Он работал, когда я назвал метод перезагрузки отдельной задачей.

gulp.task('browserSync', function() {
  browserSync.init(null, {
    server: {
      baseDir: './'
    },
  });
})

gulp.task('reload', function(){
    browserSync.reload()
})

gulp.task('watch', ['sass', 'css', 'browserSync'], function(){
   gulp.watch('*.html', ['reload']);
})