gulp经常使用插件之gulp-postcss使用

更多gulp经常使用插件使用请访问:gulp经常使用插件汇总css


** gulp-postcss**这是一款经过多个插件经过管道传递CSS,可是仅解析一次CSS。html

更多使用文档请点击访问gulp-postcss工具官网git

安装

一键安装很少解释github

npm install --save-dev gulp-postcss

使用

单独安装所需的postcss插件。例如,对于autoprefixer,您须要安装autoprefixer软件包。npm

基本用法gulp

postcss(options) 工具

  • options(参数) 类型:Array or null

配置是从自动加载postcss.config.js 这里描述的,因此你没必要指定任何选项。post

var postcss = require('gulp-postcss');
var gulp = require('gulp');

gulp.task('css', function () {
    return gulp.src('./src/*.css')
        .pipe(postcss())
        .pipe(gulp.dest('./dest'));
});

直接传递插件ui

var postcss = require('gulp-postcss');
var gulp = require('gulp');
var autoprefixer = require('autoprefixer');
var cssnano = require('cssnano');

gulp.task('css', function () {
    var plugins = [
        autoprefixer({browsers: ['last 1 version']}),
        cssnano()
    ];
    return gulp.src('./src/*.css')
        .pipe(postcss(plugins))
        .pipe(gulp.dest('./dest'));
});

将其余选项传递给PostCSS gulp-postcss的第二个可选参数传递给PostCSS。 例如,这可用于启用自定义解析器:spa

var gulp = require('gulp');
var postcss = require('gulp-postcss');
var nested = require('postcss-nested');
var sugarss = require('sugarss');

gulp.task('default', function () {
    var plugins = [nested];
    return gulp.src('in.sss')
        .pipe(postcss(plugins, { parser: sugarss }))
        .pipe(gulp.dest('out'));
});

使用自定义处理器

var postcss = require('gulp-postcss');
var cssnext = require('postcss-cssnext');
var opacity = function (css, opts) {
    css.eachDecl(function(decl) {
        if (decl.prop === 'opacity') {
            decl.parent.insertAfter(decl, {
                prop: '-ms-filter',
                value: '"progid:DXImageTransform.Microsoft.Alpha(Opacity=' + (parseFloat(decl.value) * 100) + ')"'
            });
        }
    });
};

gulp.task('css', function () {
    var plugins = [
        cssnext({browsers: ['last 1 version']}),
        opacity
    ];
    return gulp.src('./src/*.css')
        .pipe(postcss(plugins))
        .pipe(gulp.dest('./dest'));
});

源地图支持

默认状况下,源地图是禁用的,以与gulp-sourcemaps一块儿提取地图。

return gulp.src('./src/*.css')
    .pipe(sourcemaps.init())
    .pipe(postcss(plugins))
    .pipe(sourcemaps.write('.'))
    .pipe(gulp.dest('./dest'));

高级用法

若是要在每一个文件基础上配置postcss,则能够传递一个回调,该回调接收vinyl 文件对象并返回 { plugins: plugins, options: options }。例如,当您须要不一样地解析不一样的扩展名时:

var gulp = require('gulp');
var postcss = require('gulp-postcss');

gulp.task('css', function () {
    function callback(file) {
        return {
            plugins: [
                require('postcss-import')({ root: file.dirname }),
                require('postcss-modules')
            ],
            options: {
                parser: file.extname === '.sss' ? require('sugarss') : false
            }
        }
    }
    return gulp.src('./src/*.css')
        .pipe(postcss(callback))
        .pipe(gulp.dest('./dest'));
});

使用能够实现相同的结果 postcss-load-config,由于它ctx与上下文选项和乙烯基文件一块儿接收。

var gulp = require('gulp');
var postcss = require('gulp-postcss');

gulp.task('css', function () {
    var contextOptions = { modules: true };
    return gulp.src('./src/*.css')
        .pipe(postcss(contextOptions))
        .pipe(gulp.dest('./dest'));
});
module.exports = function (ctx) {
    var file = ctx.file;
    var options = ctx.options;
    return {
        parser: file.extname === '.sss' ? : 'sugarss' : false,
        plugins: {
           'postcss-import': { root: file.dirname }
           'postcss-modules': options.modules ? {} : false
        }
    }
})
相关文章
相关标签/搜索