1.7.0 • Published 24 days ago

postcss-html v1.7.0

Weekly downloads
2,136,294
License
MIT
Repository
github
Last release
24 days ago

PostCSS HTML Syntax

NPM license NPM version NPM downloads NPM downloads NPM downloads Build Status

PostCSS syntax for parsing HTML (and HTML-like)

Getting Started

First thing's first, install the module:

npm install postcss-html --save-dev

If you want support SCSS/SASS/LESS/SugarSS syntax, you need to install the corresponding module.

Use Cases

const postcss = require('postcss');
const syntax = require('postcss-html')({
    // syntax for parse scss (non-required options)
    scss: require('postcss-scss'),
    // syntax for parse less (non-required options)
    less: require('postcss-less'),
    // syntax for parse css blocks (non-required options)
    css: require('postcss-safe-parser'),
});
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
});

If you want support SCSS/SASS/LESS/SugarSS syntax, you need to install these module:

Advanced Use Cases

Options

const options = {
    rules: [
        {
            // custom language
            test: /^postcss$/i,
            lang: 'scss'
        },
        {
            // custom language
            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: require.resolve('./node_modules/postcss-less'),
    // custom parser for SugarSS
    sugarss: require('sugarss'),
    // custom parser for custom language
    custom: require('postcss-custom-syntax'),
}
const syntax = require('postcss-html')(options);

Turning PostCSS off from within your HTML

PostCSS can be temporarily turned off by using special comments in your HTML. For example:

<html>
<body>
<!-- postcss-ignore -->
<a style="color: red;" description="style is not parsed."></a>

<a style="color: red;" description="style is parsed."></a>
<html>
<body>
<!-- postcss-disable -->
<a style="color: red;" description="style is not parsed."></a>
<a style="color: red;" description="style is not parsed."></a>
<!-- postcss-enable -->

<a style="color: red;" description="style is parsed."></a>

Linting with Stylelint

The main use case of this plugin is to apply linting with Stylelint to <style> tags and <div style="*"> property in HTML (and HTML-like).

You can use it by configuring your stylelint config as follows:

{
    "overrides": [
        {
            "files": ["*.html", "**/*.html"],
            "customSyntax": "postcss-html"
        }
    ]
}

You can use it more easily if you use an already configured sharable config.

{
+    "extends": [
+        "stylelint-config-html",
         // If you are using Vue.
+        "stylelint-config-recommended-vue"
+    ],
-    "overrides": [
-        {
-            "files": ["*.html", "**/*.html"],
-            "customSyntax": "postcss-html"
-        }
-    ]
}
@hovey/stylelint-config-basic@frog-res/stylelint-config-vue-scssstylelint-common-config@clevercanyon/utilities-dev-npm@infinitebrahmanuniverse/nolb-postcss-h@longwoo/stylelint-config-standard@wfly/config-lint@cmsk/stylelint-config@redco/stylelint-config-hdred@everything-registry/sub-chunk-2460@ucstu/fast-nuxt-app@sacc/stylelint-config@beardeddudes-dev/postcss-configgreat-harmonyk100-lintergulp-html-postcssh-com-lintersgwscjg-uihfex-stylelint-configmto-lintmr-style-lintneutrino-preset-fabrikamoqoyeelight-fabricvue-ellipsis-tooltipluoshendfeuk-frontenddfeuk-frontend-manualpptx-prompterstylelint-config-wikimediastylelint-config-wyxstylelint-config-ygxystylelint-config-vue-lintstylelint-config-zc93stylelint-config-jazstylelint-config-kerorostylelint-config-longyingstylelint-config-mrtnvhstylelint-config-muhqstylelint-config-myselfstylelint-config-coinspacestylelint-config-coralloystylelint-config-crispstylelint-config-bodstylelint-config-evionicastylelint-config-customstylelint-config-rchlstylelint-config-akrcstylelint-config-test121stylelint-config-silverwindstylelint-config-sissstylelint-config-smartstylelint-config-smartsstylelint-config-speedstylelint-config-standard-onestylelint-config-svelte-robolearystylelint-config-taqustylelint-stylusss-configvscode-lint4cs-cli@-ysh-/code-specification-unid@agro-expo/rules@agro-tech/rules@alexlit/config-stylelint@adbros/stylelint-config@anthony-ju/stylelint-config@1stg/stylelint-config@argo-design/argo-lint@baberat/stylelint-config-beita@fisker/stylelint-config@geneticure/util@gem-universe/stylelint-config@funish/stylelint-config@easytool/stylelint-config@dylan66ty/stylelint-config@duanke/stylelint-config@duckies/stylelint-config-scss@dvcol/stylelint-plugin-presets@dword-design/stylelint-config@elux/stylelint-config@eye-socket/stylelint-config@fastkit/stylelint-config@elliemae/pui-cli@fabwcie/ckeditor5-preview@gx-web/stylelint-config@handsomewolf/scss-tools@hankliu/lint@haltcase/style@grixu/stylelint-config@hjkltop/genesis-lint@hydenliu/stylelint-config@lint-my-life/stylelint-paintbrush@lint-my-life/stylelint-vue@lint-my-life/stylelint-vue-scss@maiscrm/stylelint-config-standard@magister_zito/stylelint-config@littlemissrobot/stylelint-config@loongwoo/stylelint-config-standard@modyqyw/fabric
1.7.0

24 days ago

1.6.0

5 months ago

1.5.0

2 years ago

1.4.1

2 years ago

1.4.0

2 years ago

1.3.1

2 years ago

1.3.0

3 years ago

1.2.0

3 years ago

1.1.1

3 years ago

1.1.0

3 years ago

1.0.2

3 years ago

1.0.1

3 years ago

1.0.0

3 years ago

1.0.0-alpha.4

3 years ago

1.0.0-alpha.3

3 years ago

1.0.0-alpha.2

3 years ago

0.36.0

5 years ago

0.34.0

6 years ago

0.33.0

6 years ago

0.32.0

6 years ago

0.31.0

6 years ago

0.30.0

6 years ago

0.28.0

6 years ago

0.27.0

6 years ago

0.26.0

6 years ago

0.25.0

6 years ago

0.24.0

6 years ago

0.23.7

6 years ago

0.23.6

6 years ago

0.23.5

6 years ago

0.23.4

6 years ago

0.23.3

6 years ago

0.23.2

6 years ago

0.23.1

6 years ago

0.23.0

6 years ago

0.22.0

6 years ago

0.21.0

6 years ago

0.20.1

6 years ago

0.20.0

6 years ago

0.19.0

6 years ago

0.18.0

6 years ago

0.17.0

6 years ago

0.16.0

6 years ago

0.15.0

6 years ago

0.14.0

6 years ago

0.13.0

6 years ago

0.12.0

6 years ago

0.11.0

7 years ago

0.10.0

7 years ago

0.9.0

7 years ago

0.8.0

7 years ago

0.7.0

7 years ago

0.6.0

7 years ago

0.5.0

7 years ago

0.4.0

7 years ago

0.3.0

7 years ago

0.2.0

7 years ago

0.1.0

7 years ago