Gulp ruby​​-sass和autoprefixer不相处

时间:2014-11-21 19:32:35

标签: sass gulp gulp-sass autoprefixer

我的gulpfile中有一个styles任务:

gulp.task('styles', function () {
  var sass = require('gulp-ruby-sass');
  var autoprefixer = require('gulp-autoprefixer');
    return gulp.src('app/styles/main.scss')
    .pipe(sass({sourcemap: true, sourcemapPath: '../scss'}))
    .on('error', function (err) { console.log(err.message); })
    .pipe(autoprefixer({
        browsers: ['last 2 versions'],
        cascade: false
    }))
    .pipe(gulp.dest('.tmp/styles'));
});

在控制台中生成它:

[14:25:21] Starting 'styles'...
[14:25:21] gulp-ruby-sass: stderr: DEPRECATION WARNING: Passing --sourcemap without a value is    deprecated.
Sourcemaps are now generated by default, so this flag has no effect.
[14:25:21] gulp-ruby-sass: directory
[14:25:25] gulp-ruby-sass: write main.css
  write main.css.map

  events.js:72
    throw er; // Unhandled 'error' event
          ^
  Error: /Users/stevelombardi/Documents/command-central/ccgulp/main.css.map:3:3: Unknown word

如果我将管道注释到autoprefixer,没有错误,一切都会编译。这是什么交易?

注意,我似乎也无法禁用源图的编写。我从repo页面尝试了grunt-ruby-sass的所有其他设置,但没有工作。

我可以在没有autoprefixer的情况下生活,但是我希望能让它工作......

2 个答案:

答案 0 :(得分:6)

这个问题似乎与 main.css.map 有关,即使你不想要一个,在我写这篇文章时使用gulp-ruby-sass@0.7.1

到目前为止,我遇到了两种不同的解决方案:

1)如果您需要源图:

gulp.task('styles', function() {
    gulp.src('app/styles/main.scss')
        .pipe(sass({
            "sourcemap=none": true // hack to allow auto-prefixer to work
        }))
        .pipe(prefix("last 2 versions"))
        .pipe(gulp.dest('css'));
});

这是我最近遇到过的问题。

2)如果你需要源图:

然后你应该尝试gulp-ruby-sass@1.0.0-alpha

relevent github issue

答案 1 :(得分:2)

而不是:

browsers: ['last 2 versions'],

试试这个:

browsers: ['last 2 version'],

如果这样做不起作用,我就可以通过gulp-sass和gulp-sourcemaps获得更好的运气。

// Compile Sass & create sourcemap
.pipe(sourcemaps.init())
    .pipe(sass())
.pipe(sourcemaps.write())
.pipe(gulp.dest('css'))

// Autoprefix, load existing sourcemap, create updated sourcemap
.pipe(sourcemaps.init({loadMaps: true}))
    .pipe(autoprefixer('last 2 version')
.pipe(sourcemaps.write('./'))
.pipe(gulp.dest('css'))