gulp-ruby-sass找不到mixins

时间:2014-02-19 01:51:41

标签: sass mixins gulp

我刚刚开始使用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。

1 个答案:

答案 0 :(得分:1)

@include应指向您在同一文件开头导入的mixin或库。

你在开头和左边的地方都缺少了@import(10px);来自, 如果它是你自己的mixin或罗盘库,它必须先导入。