Задать вопрос
CheckOneTwo
@CheckOneTwo
Парень, который думает что он фронтэндер.

Как разделить поток на несколько файлов в Gulp.js?

Всем привет, у меня есть один таск в gulpfile.js:

var global_css = [
        './source/sass/global/*.scss',
        './source/sass/features/*.scss',
        './source/sass/pages/*.scss',
        './source/sass/layout/*.scss'
    ];

gulp.task('sass-global', function () {

            return gulp.src(global_css)
                .pipe(plugins.plumber({errorHandler: plugins.notify.onError("<%= error.message %>")}))
                .pipe(plugins.sourcemaps.init())
                .pipe(plugins.sass())
                .pipe(plugins.autoprefixer({
                    browsers: prefix_list,
                    cascade: false
                }))
                .pipe(plugins.csscomb('./dev/libs/comb/research.json'))
                .pipe(plugins.sourcemaps.write('./'))
                .pipe(gulp.dest('./public/css'));
        });


Можно ли сделать так чтобы в одном таком таске, каждая указанная папка в global_css конкатинировалась в отдельный файл и потом уже по этому файлу проходились CSScomb Прехифаер и Сурсмап?
  • Вопрос задан
  • 1088 просмотров
Подписаться 1 Оценить Комментировать
Решения вопроса 1
voidnugget
@voidnugget
Программист-прагматик
var merge = require('merge-stream');
gulp.task('sass-global', function () {
  var merged = merge();
  global_css.forEach((entry) => {
    merged.add(gulp.src(entry)
      .pipe(plugins.plumber({errorHandler: plugins.notify.onError("<%= error.message %>")}))
      .pipe(plugins.sourcemaps.init())
      .pipe(plugins.sass())
      .pipe(plugins.autoprefixer({
        browsers: prefix_list,
        cascade: false
      }))
      .pipe(plugins.csscomb('./dev/libs/comb/research.json'))
      .pipe(plugins.sourcemaps.write('./'))
      .pipe(gulp.dest('./public/css')));
  });

  return merged;
});


Типа так
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы