1.6.0 • Published 3 months ago

postcss-html v1.6.0

Weekly downloads
2,136,294
License
MIT
Repository
github
Last release
3 months 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-configdmlint@denaro-config/stylelint-less@denaro-config/stylelint-scssdfeuk-frontenddfeuk-frontend-manual@devops-web/stylelint-config@democrance/stylelint-config@draymond37/code-style@deviltea/stylelint-config-scssfe-ent-clife-ent-vitefejn-stylelint-configfrabbit-stylelinteslint-config-energysageeslint-config-vue2-uni-app@haltcase/style@handsomewolf/scss-tools@hankliu/lint@geneticure/util@houheaven/stylelint-config-helper@hovey/stylelint-config@hydenliu/stylelint-config@hjkltop/genesis-lint@gem-universe/stylelint-config@grixu/stylelint-config@bn-digital/postcss-config@cedric-ruiu/stylelint-config@chansee97/stylelint-config@chaos1ee/stylelint-config-vue@citruslime/configec0lint-style-config-postcss@elliemae/pui-cligulp-html-postcssmoqogreat-harmony@erhang/stylelint-config@epay-sparta/cli-service@elux/stylelint-configmr-style-lintmto-lint@easytool/stylelint-config@dword-design/stylelint-config@dylan66ty/stylelint-config@faxjs/stylelint-config@fabwcie/ckeditor5-preview@fastkit/stylelint-config@fisker/stylelint-configgwscjg-uih-com-linters@eye-socket/stylelint-config@duanke/stylelint-config@duckies/stylelint-config-scss@dvcol/stylelint-plugin-presetshfex-stylelint-config@fmfe/genesis-lint@fmfe/lib-genesis-lintneutrino-preset-fabrika@fruktorum/stylelint-config@funish/stylelint-config@ifanrx/stylelint-config-standard-vue@indielayer/stylelint-config@hzzlyxx/stylelint-config-scss@ithinkdt/eslint-config@jvbjs/stylelint-config@justichentai/stylelint-config@jhqn/vuek100-linter@keloop/stylelint-config@jungzl/stylelint-config@jinxyang/react-cli@jhqn/stylelint-configluoshen@obciid/stylelint-config@nice-move/stylelint-config@nitra/stylelint-config@nharox/astro-stylelint-config@oriduk/ckeditor5-rebuild-musicanote@oriduk/ckeditor5-rebuild-oriduk@ohmsd/dev-conf@ntnyq/stylelint-config-vue@nw-web/lint@novicell/stylelint-config@panmenghan/starter-ui@postanu/stylelint-config@pospal/prettier-config@pospal/stylelint-config@pokemonon/stylelint-config-formatter
1.6.0

3 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

2 years ago

1.2.0

2 years ago

1.1.1

2 years ago

1.1.0

2 years ago

1.0.2

2 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

6 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