0

我刚刚开始使用 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 的东西都工作正常。只是 mixin 会引发错误。

我已经安装Compass 0.12.2

我错过了任何宝石/模块吗?

该系统在带有 Ubuntu 虚拟机的 Vagrant 上运行。

4

1 回答 1

1

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

你在开头和左边都不见了@import(10px);来自,如果它是您自己的 mixin 或指南针库,则必须先导入。

于 2014-02-19T17:50:40.840 回答