scss [`postcss-sass`]: https://github.com/AleshaOleg/postcss-sass [`postcss-less`]: https://github.com/webschik/postcss-less [`postcss-js`]: https://github.com/postcss/postcss-js [`sugarss`]: https://github.com/postcss/sugarss [`midas`]: https://github.com/ben-eb/midas ## 文章 * [一些你对 PostCSS 可能产生的误解](http://julian.io/some-things-you-may-think-about-postcss-and-you-might-be-wrong) * [PostCSS 究竟是什么,是做什么的](http://davidtheclark.com/its-time-for-everyone-to-learn-about-postcss) * [PostCSS 指南](http://webdesign.tutsplus.com/series/postcss-deep-dive--cms-889) 你可以在 [awesome-postcss](https://github.com/jjaderg/awesome-postcss) 列表里找到更多优秀的文章和视频。 ## 书籍 * Alex Libby, Packt 的 [网页设计之精通 PostCSS](https://www.packtpub.com/web-development/mastering-postcss-web-design) (2016年6月) ## 使用方法 你可以通过简单的两步便开始使用 PostCSS: 1. 在你的构建工具中查找并添加 PostCSS 拓展。 2. [选择插件]并将它们添加到你的 PostCSS 处理队列中。 [选择插件]: http://postcss.parts ### Webpack 在 `webpack.config.js` 里使用 [`postcss-loader`] : ```js module.exports = { module: { rules: [ { test: /\.css$/, exclude: /node_modules/, use: [ { loader: 'style-loader', }, { loader: 'css-loader', options: { importLoaders: 1, } }, { loader: 'postcss-loader' } ] } ] } } ``` 然后创建 `postcss.config.js`: ```js module.exports = { plugins: [ require('precss'), require('autoprefixer') ] } ``` [`postcss-loader`]: https://github.com/postcss/postcss-loader ### Gulp 使用 [`gulp-postcss`] 和 [`gulp-sourcemaps`]. ```js gulp.task('css', function () { var postcss = require('gulp-postcss'); var sourcemaps = require('gulp-sourcemaps'); return gulp.src('src/**/*.css') .pipe( sourcemaps.init() ) .pipe( postcss([ require('precss'), require('autoprefixer') ]) ) .pipe( sourcemaps.write('.') ) .pipe( gulp.dest('build/') ); }); ``` [`gulp-sourcemaps`]: https://github.com/floridoo/gulp-sourcemaps [`gulp-postcss`]: https://github.com/postcss/gulp-postcss ### npm run / CLI 如果需要在你的命令行界面或 npm 脚本里使用 PostCSS,你可以使用 [`postcss-cli`]。 ```sh postcss --use autoprefixer -c options.json -o main.css css/*.css ``` [`postcss-cli`]: https://github.com/postcss/postcss-cli ### 浏览器 如果你想编译浏览器里的 CSS 字符串(例如像 CodePen 一样的在线编辑器), 只需使用 [Browserify] 或 [webpack]。它们会把 PostCSS 和插件文件打包进一个独立文件。 如果想要在 React 内联样式/JSS/Radium/其它 [CSS-in-JS] 里使用 PostCSS, 你可以用 [`postcss-js`] 然后转换样式对象。 ```js var postcss = require('postcss-js'); var prefixer = postcss.sync([ require('autoprefixer') ]); prefixer({ display: 'flex' }); //=> { display: ['-webkit-box', '-webkit-flex', '-ms-flexbox', 'flex'] } ``` [`postcss-js`]: https://github.com/postcss/postcss-js [Browserify]: http://browserify.org/ [CSS-in-JS]: https://github.com/MicheleBertoli/css-in-js [webpack]: https://webpack.github.io/ ### 运行器 * **Grunt**: [`grunt-postcss`](https://github.com/nDmitry/grunt-postcss) * **HTML**: [`posthtml-postcss`](https://github.com/posthtml/posthtml-postcss) * **Stylus**: [`poststylus`](https://github.com/seaneking/poststylus) * **Rollup**: [`rollup-plugin-postcss`](https://github.com/egoist/rollup-plugin-postcss) * **Brunch**: [`postcss-brunch`](https://github.com/brunch/postcss-brunch) * **Broccoli**: [`broccoli-postcss`](https://github.com/jeffjewiss/broccoli-postcss) * **Meteor**: [`postcss`](https://atmospherejs.com/juliancwirko/postcss) * **ENB**: [`enb-postcss`](https://github.com/awinogradov/enb-postcss) * **Taskr**: [`taskr-postcss`](https://github.com/lukeed/taskr/tree/master/packages/postcss) * **Start**: [`start-postcss`](https://github.com/start-runner/postcss) * **Connect/Express**: [`postcss-middleware`](https://github.com/jedmao/postcss-middleware) ### JS API 对于其它的应用环境,你可以使用 JS API: ```js const fs = require('fs'); const postcss = require('postcss'); const precss = require('precss'); const autoprefixer = require('autoprefixer'); fs.readFile('src/app.css', (err, css) => { postcss([precss, autoprefixer]) .process(css, { from: 'src/app.css', to: 'dest/app.css' }) .then(result => { fs.writeFile('dest/app.css', result.css); if ( result.map ) fs.writeFile('dest/app.css.map', result.map); }); }); ``` 阅读 [PostCSS API 文档] 获取更多有关 JS API 的信息. 所有的 PostCSS 运行器应当通过 [PostCSS 运行器指南]。 [PostCSS 运行器指南]: https://github.com/postcss/postcss/blob/master/docs/guidelines/runner.md [PostCSS API 文档]: http://api.postcss.org/postcss.html ### 配置选项 绝大多数 PostCSS 运行器接受两个参数: * 一个包含所需插件的数组 * 一个配置选项的对象 常见的选项: * `syntax`: 一个提供了语法解释器和 stringifier 的对象。 * `parser`: 一个特殊的语法解释器(例如 [SCSS])。 * `stringifier`: 一个特殊的语法 output 生成器(例如 [Midas])。 * `map`: [source map 选项]. * `from`: input 文件名称(大多数运行器自动设置了这个)。 * `to`: output 文件名称(大多数运行器自动设置了这个)。 [source map 选项]: https://github.com/postcss/postcss/blob/master/docs/source-maps.md [Midas]: https://github.com/ben-eb/midas [SCSS]: https://github.com/postcss/postcss-scss ### Atom * [`language-postcss`] 添加了 PostCSS 和 [SugarSS] 代码高亮。 * [`source-preview-postcss`] 在一个独立窗口里实时预览生成的 CSS。 [SugarSS]: https://github.com/postcss/sugarss ### Sublime Text * [`Syntax-highlighting-for-PostCSS`] 添加了 PostCSS 代码高亮。 [`Syntax-highlighting-for-PostCSS`]: https://github.com/hudochenkov/Syntax-highlighting-for-PostCSS [`source-preview-postcss`]: https://atom.io/packages/source-preview-postcss [`language-postcss`]: https://atom.io/packages/language-postcss ### Vim * [`postcss.vim`] 添加了 PostCSS 代码高亮。 [`postcss.vim`]: https://github.com/stephenway/postcss.vim ### WebStorm 自 WebStorm 2016.3 开始,[提供了] 内建的 PostCSS 支持。 [提供了]: https://blog.jetbrains.com/webstorm/2016/08/webstorm-2016-3-early-access-preview/