【问题标题】:Gulp livereload reloads the entire page when only CSS has changedGulp livereload 仅在 CSS 更改时重新加载整个页面
【发布时间】:2015-12-14 17:30:11
【问题描述】:

我已将 livereload 添加到我的 Gulp 任务中。它的工作原理是当我编辑一个 CSS 文件时,整个页面都会被刷新,而不仅仅是页面 CSS。

 var gulp = require('gulp');
 var uglify = require('gulp-uglify');
 var concat = require('gulp-concat');
 var minifyCss = require('gulp-minify-css');
 var sizereport = require('gulp-sizereport');
 var watch = require('gulp-watch');
 var batch = require('gulp-batch');
 var run = require('run-sequence');

gulp.task('watch-theme-css', ['theme-css'], function () {
  livereload.listen();
  watch(themeFiles.sass, batch(function (events, done) {
    gulp.start('theme-css', done);
  }))
});

var themeFiles = {
  sass: [
    'mysite/base/sass/*.s+(a|c)ss',
    'mysite/content/sass/*.s+(a|c)ss',
    'mysite/custom/sass/*.s+(a|c)ss'
  ],
  out: {
    css: 'mysite/build'
  }
};

gulp.task('theme-css', function () {
  return gulp.src(themeFiles.sass)
    .pipe(gulpif(env === 'development', sourcemaps.init()))
    .pipe(sass().on('error', sass.logError))
    .pipe(minifyCss({
      compatibility: 'ie8'
    }))
    .pipe(gulpif(env === 'dev', sourcemaps.write('.')))
    .pipe(gulp.dest(themeFiles.out.css))
    .pipe(livereload());
});

更新我已经尝试了下面链接中的以下代码,但它做同样的事情。 http://www.roelvanlisdonk.nl/?p=4675

gulp.task('watch-theme-css', ['theme-css'], function () {
  livereload.listen();
  watch(themeFiles.sass, batch(function (events, done) {
    gulp.start('theme-css', done);
  }), ["reloadCss"]);
});

同样的行为:https://laracasts.com/discuss/channels/tips/proper-way-to-use-livereload-with-laravel-elixir

gulp.task('watch-lr-css', ['theme-css'], function () {
  livereload.changed(themeFiles.sass);
});

我尝试了以下方法,但是当我尝试打开实时重新加载浏览器插件时,它说它找不到实时重新加载服务器。 gulp: how to update the browser without refresh (for css changes only)

gulp.task('watch-theme-css', ['theme-css'], function () {
  //livereload.listen();
  livereload.changed(themeFiles.sass);
  watch(themeFiles.sass, batch(function (events, done) {
    gulp.start('theme-css', done);
  }));
});

【问题讨论】:

  • 不是答案,但我建议您评估浏览器同步。这很漂亮。
  • 您能否在问题中包含导入语句?
  • @Bern 你是什么意思?
  • 导入 gulp 插件的位置
  • 对不起,require 声明。语言错误。

标签: gulp-livereload


【解决方案1】:

我昨晚在这上面花了几个小时,发现了这个:https://github.com/vohof/gulp-livereload/issues/93

看起来是因为您的源地图。 gulp-livereload 试图变得聪明,只有在只有 css 更改时才重新加载 css。否则它会重新加载整个页面,因为它认为还有更多文件发生了变化。

因此,您只需在调用 livereload() 函数之前将 glob 过滤为仅 css。

所以这样的事情可能会有所帮助:

var filter = require('gulp-filter');

...

gulp.task('theme-css', function () {
  return gulp.src(themeFiles.sass)
    .pipe(gulpif(env === 'development', sourcemaps.init()))
    .pipe(sass().on('error', sass.logError))
    .pipe(minifyCss({
      compatibility: 'ie8'
    }))
    .pipe(gulpif(env === 'dev', sourcemaps.write('.')))
    .pipe(gulp.dest(themeFiles.out.css))

    // Add filter here
    .pipe(filter('**/*.css'))
    .pipe(livereload());
});

【讨论】:

  • 您先生是一位绅士和一位学者。我花了几个小时寻找这个答案。
【解决方案2】:

当发生更改时,您需要调用 livereload.changed(files)。为此,请参阅 gulp-watch 文档。

watch('**/*.js', function (files) {
  livereload.changed(files)
});

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2015-03-27
    • 1970-01-01
    • 2013-10-01
    • 1970-01-01
    • 2015-03-29
    • 1970-01-01
    • 2017-01-10
    相关资源
    最近更新 更多