lhl 6ff0e96ad3 8-4-1 1 year ago
..
LICENSE 6ff0e96ad3 8-4-1 1 year ago
README.md 6ff0e96ad3 8-4-1 1 year ago
document.js 6ff0e96ad3 8-4-1 1 year ago
get-lang.js 6ff0e96ad3 8-4-1 1 year ago
get-syntax.js 6ff0e96ad3 8-4-1 1 year ago
index.js 6ff0e96ad3 8-4-1 1 year ago
load-syntax.js 6ff0e96ad3 8-4-1 1 year ago
normal-opts.js 6ff0e96ad3 8-4-1 1 year ago
package.json 6ff0e96ad3 8-4-1 1 year ago
parse-style.js 6ff0e96ad3 8-4-1 1 year ago
parse.js 6ff0e96ad3 8-4-1 1 year ago
parser.js 6ff0e96ad3 8-4-1 1 year ago
patch-postcss.js 6ff0e96ad3 8-4-1 1 year ago
processor.js 6ff0e96ad3 8-4-1 1 year ago
stringify.js 6ff0e96ad3 8-4-1 1 year ago
syntax.js 6ff0e96ad3 8-4-1 1 year ago

README.md

PostCSS Syntax

NPM version Travis Travis Codecov David

<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 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:

If you want support HTML (and HTML-like)/Markdown/CSS-in-JS file format, you need to install these module:

Use Cases

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
});