1

我正在使用最新的 gulp sass 和 browsersync。编辑和保存 scss 文件后,它会编译,我看到“injecting styles.css”浏览器也会重新加载。

不确定何时更改,但它过去只是注入新的 css 文件而无需重新加载。

我的任务:

var sassFiles = './app/assets/sass/**/*.{scss,sass}';
var cssFiles = './app/assets/css';
var cssBuildFiles = './build/assets/css';

var sassOptions = {
  errLogToConsole: true,
  outputStyle: 'compact'
};

var autoprefixerOptions = {
  browsers: ['last 2 versions']
};


  gulp.task('sass', function () {
  return gulp
    .src(sassFiles)
    .pipe(sourcemaps.init())
    .pipe(sass(sassOptions).on('error', sass.logError))
    .pipe(autoprefixer(autoprefixerOptions))
    .pipe(sourcemaps.write('./'))
    .pipe(gulp.dest(cssFiles))
    .pipe(browserSync.stream());
});

有一次,我使用过滤器仅将 css 文件通过管道传输到 browsersync,因为有人告诉我地图文件正在触发重新加载。不确定我是否真的需要这样做,因为大多数在线示例都与我在这里的示例一样...

4

1 回答 1

0
  1. 确保您已在初始化选项中设置injectChangestrue

    browserSync.init({
        proxy:"http://localhost:8888",
        injectChanges: true
    });
    
  2. 尝试将过滤器传递给流方法以限制注入哪些更改

browserSync.stream({match: "**/*.css"})

于 2018-12-19T14:59:42.937 回答