使用Gulp进行更改后,browser-sync不会刷新页面

时间:2015-07-01 14:10:11

标签: sass gulp browser-sync

我是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

但我必须手动重新加载。我错过了什么?

8 个答案:

答案 0 :(得分:29)

当我不熟悉浏览器同步时,我也遇到了类似的问题,命令行说“重新加载浏览器”但浏览器根本没有刷新,问题是我没有在HTML中包含body标签浏览器同步可以为其功能注入脚本的页面,确保您的HTML页面具有正文标记。

答案 1 :(得分:16)

您可以注入更改,而不必在SASS编译时强制完全浏览器刷新。

style="display:none;"

答案 2 :(得分:9)

这是因为你在html手表上而不是在scss手表上调用browserSync.reload

试试这个:

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

答案 3 :(得分:6)

这是我使用的,它在sass或任何其他文件中都很好用

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

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

答案 4 :(得分:2)

遇到同样的问题,尝试重新加载phpjs文件以及流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
        }
    });
});

答案 5 :(得分:1)

我也有同样的问题。当我将重载方法称为单独的任务时,它起了作用。

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']);
})

答案 6 :(得分:1)

有时使用CLI时,您没有在HTML主文件中插入脚本,因此您应手动添加或使用gulp。

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

答案 7 :(得分:0)

我将这个包含在我的html中,正文标签正下方。它有效。

<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>