更多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
ornull
配置是从自动加载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 } } })