| PostCSS Syntax |
| ==== |
| |
| [](https://www.npmjs.com/package/postcss-syntax) |
| [](https://travis-ci.org/gucong3000/postcss-syntax) |
| [](https://travis-ci.org/gucong3000/postcss-syntaxes) |
| [](https://codecov.io/gh/gucong3000/postcss-syntax) |
| [](https://david-dm.org/gucong3000/postcss-syntax?type=dev) |
| |
| <img align="right" width="95" height="95" |
| title="Philosopher’s stone, logo of PostCSS" |
| src="http://postcss.github.io/postcss/logo.svg"> |
| |
| postcss-syntax can automatically switch the required [PostCSS](https://github.com/postcss/postcss) syntax by file extension/source |
| |
| ## Getting Started |
| |
| First thing's first, install the module: |
| |
| ``` |
| npm install postcss-syntax --save-dev |
| ``` |
| |
| If you want support SCSS/SASS/LESS/SugarSS syntax, you need to install these module: |
| |
| - SCSS: [postcss-scss](https://github.com/postcss/postcss-scss) |
| - SASS: [postcss-sass](https://github.com/aleshaoleg/postcss-sass) |
| - LESS: [postcss-less](https://github.com/shellscape/postcss-less) |
| - SugarSS: [sugarss](https://github.com/postcss/sugarss) |
| |
| If you want support HTML (and HTML-like)/Markdown/CSS-in-JS file format, you need to install these module: |
| |
| - CSS-in-JS: [postcss-jsx](https://github.com/gucong3000/postcss-jsx) |
| - HTML (and HTML-like): [postcss-html](https://github.com/gucong3000/postcss-html) |
| - Markdown: [postcss-markdown](https://github.com/gucong3000/postcss-markdown) |
| |
| ## Use Cases |
| |
| ```js |
| const postcss = require('postcss'); |
| const syntax = require('postcss-syntax')({ |
| rules: [ |
| { |
| test: /\.(?:[sx]?html?|[sx]ht|vue|ux|php)$/i, |
| extract: 'html', |
| }, |
| { |
| test: /\.(?:markdown|md)$/i, |
| extract: 'markdown', |
| }, |
| { |
| test: /\.(?:m?[jt]sx?|es\d*|pac)$/i, |
| extract: 'jsx', |
| }, |
| { |
| // custom language for file extension |
| test: /\.postcss$/i, |
| lang: 'scss' |
| }, |
| { |
| // custom language for file extension |
| test: /\.customcss$/i, |
| lang: 'custom' |
| }, |
| ], |
| |
| // custom parser for CSS (using `postcss-safe-parser`) |
| css: 'postcss-safe-parser', |
| // custom parser for SASS (PostCSS-compatible syntax.) |
| sass: require('postcss-sass'), |
| // custom parser for SCSS (by module name) |
| scss: 'postcss-scss', |
| // custom parser for LESS (by module path) |
| less: './node_modules/postcss-less', |
| // custom parser for SugarSS |
| sugarss: require('sugarss'), |
| // custom parser for custom language |
| custom: require('postcss-custom-syntax'), |
| |
| }); |
| postcss(plugins).process(source, { syntax: syntax }).then(function (result) { |
| // An alias for the result.css property. Use it with syntaxes that generate non-CSS output. |
| result.content |
| }); |
| ``` |