我刚刚开始使用Gulp.js和Sass,而且我一直坚持使用mixins。
这是我的gulp.js
文件:
var gulp = require('gulp');
var autoprefixer = require('gulp-autoprefixer');
var sass = require('gulp-ruby-sass');
gulp.task('css', function(){
return gulp.src('./assets/scss/main.scss')
.pipe(sass({
style: 'expanded',
noCache: true
}))
.pipe(autoprefixer('last 5 versions'))
.pipe(gulp.dest('./assets/css'));
});
gulp.task('watch', function(){
gulp.watch('./assets/scss/*.scss', ['css']);
});
gulp.task('default', ['css', 'watch']);
这是我的main.scss文件:
#data {
@include left(10px);
@include table-base;
}
这是它产生的错误:
events.js:72
throw er; // Unhandled 'error' event
^
[gulp] Error in plugin 'gulp-ruby-sass':
Syntax error: Undefined mixin 'left'.
on line 2 of /vagrant/gulp_test_1/assets/scss/main.scss, in `left'
from line 2 of /tmp/a4d96d4a-b823-4828-a37c-eab307477784/main.scss
at ChildProcess.<anonymous> (/vagrant/gulp_test_1/node_modules/gulp-ruby-sass/index.js:74:25)
at ChildProcess.EventEmitter.emit (events.js:98:17)
at maybeClose (child_process.js:743:16)
at Process.ChildProcess._handle.onexit (child_process.js:810:5)
所有其他Sass的工作正常。只是mixins会引发错误。
我安装了Compass 0.12.2
我错过了任何宝石/模块吗?
系统在Vagrant上运行,带有Ubuntu VM。
答案 0 :(得分:1)
@include应指向您在同一文件开头导入的mixin或库。
你在开头和左边的地方都缺少了@import(10px);来自, 如果它是你自己的mixin或罗盘库,它必须先导入。