我的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的情况下生活,但是我希望能让它工作......
答案 0 :(得分:6)
这个问题似乎与 main.css.map 有关,即使你不想要一个,在我写这篇文章时使用gulp-ruby-sass@0.7.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'));
});
这是我最近遇到过的问题。
然后你应该尝试gulp-ruby-sass@1.0.0-alpha
答案 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'))