gulp任务合并生成的sass事件流作为所需的顺序不起作用

时间:2015-05-30 00:06:41

标签: gulp gulp-sass event-stream

我有三个bootstrap sass和另外两个sass文件,我正在编译并合并到一个css中。在bootstrap上我正在运行" unss"为了摆脱未使用的CSS,但对于其他人我没有运行" uncss"因为我不想要。合并这些我正在使用" eventstream"。不幸的是,生成的组合css文件的顺序不符合我的要求。无论如何,bootstrap css文件始终在最后打印,这会导致问题。以下是我的gulp任务

while(fgets(buffer, MAX_LINELENGTH, textFile))
{
    // process the line
}

在最终生成的my-final-site.css中,css按以下顺序打印

var eventStream = require('event-stream'),
        sass = require('gulp-sass'),
        uncss = require('gulp-uncss'),
        csso = require('gulp-csso'),
        concat = require('gulp-concat');

gulp.task('sass', function () {
    //Copy bootstrap fonts files
    gulp.src(config.sassPath + '/vendor/bootstrap-sass-3.3.2/assets/fonts/**/*')
            .pipe(gulp.dest(config.cssPath + '/fonts'));


    //compile bootstrap css, compress and remove unused css rules
    var bootstrapCss = gulp.src(config.sassPath + '/vendor/custom/custom-bootstrap.scss')
            .pipe(sass({outputStyle: 'compressed'}))
            .pipe(uncss({
                html: ['./application/public/templates/**/*.html']
            }))
            .pipe(csso());

    //Compile slick css file to compress it
    var slickCss = gulp.src(config.sassPath + '/vendor/slick/slick.scss')
            .pipe(sass({outputStyle: 'compressed'}));

    //Compile mysite css file and compress it
    var mysiteCss = gulp.src(config.sassPath + '/application/my-site.scss')
            .pipe(sass({outputStyle: 'compressed'}));

    //merge all css
    eventStream.merge(slickCss, mysiteCss, bootstrapCss)
            .pipe(concat('my-final-site.css'))
            .pipe(gulp.dest(config.cssPath + '/stylesheets'));

});

我想将引导程序保持在最顶层,以便我的自定义引导程序代码可以正常工作。

请帮忙。

1 个答案:

答案 0 :(得分:1)

你可以像这样编写自定义比较器

// sort with a custom comparator 
gulp.src('./src/js/**/*.js')
.pipe(sort({
    comparator: function(file1, file2) {
        if (file1.path.indexOf('build') > -1) {
            return 1;
        }
        if (file2.path.indexOf('build') > -1) {
            return -1;
        }
        return 0;
    }
}))
.pipe(gulp.dest('./build/js'));

详细了解here