postcss-dir-pseudo-class

Use the :dir pseudo-class in CSS

MIT-0 21 个版本
安装
npm install postcss-dir-pseudo-class
yarn add postcss-dir-pseudo-class
pnpm add postcss-dir-pseudo-class
bun add postcss-dir-pseudo-class
README

PostCSS Dir Pseudo Class PostCSS Logo

npm install postcss-dir-pseudo-class --save-dev

PostCSS Dir Pseudo Class lets you style by directionality using the :dir() pseudo-class in CSS, following the Selectors specification.

article h3:dir(rtl) {
	margin-right: 10px;
}

article h3:dir(ltr) {
	margin-left: 10px;
}

/* becomes */

[dir="rtl"] article h3 {
	margin-right: 10px;
}

[dir="ltr"] article h3 {
	margin-left: 10px;
}

Maintaining Specificity

Using PostCSS Dir Pseudo Class will not impact selector weight, but it will require having at least one [dir] attribute in your HTML. If you don’t have any [dir] attributes, consider using the following JavaScript:

// force at least one dir attribute (this can run at any time)
document.documentElement.dir=document.documentElement.dir||'ltr';

If you absolutely cannot add a [dir] attribute in your HTML or even force one via JavaScript, you can still work around this by presuming a direction in your CSS using the dir option, but understand that this will sometimes increase selector weight by one element (html).

Usage

Add PostCSS Dir Pseudo Class to your project:

npm install postcss postcss-dir-pseudo-class --save-dev

Use it as a PostCSS plugin:

const postcss = require('postcss');
const postcssDirPseudoClass = require('postcss-dir-pseudo-class');

postcss([
	postcssDirPseudoClass(/* pluginOptions */)
]).process(YOUR_CSS /*, processOptions */);

Options

preserve

The preserve option determines whether the original notation is preserved. By default, it is not preserved.

postcssDirPseudoClass({ preserve: true })
article h3:dir(rtl) {
	margin-right: 10px;
}

article h3:dir(ltr) {
	margin-left: 10px;
}

/* becomes */

[dir="rtl"] article h3 {
	margin-right: 10px;
}

article h3:dir(rtl) {
	margin-right: 10px;
}

[dir="ltr"] article h3 {
	margin-left: 10px;
}

article h3:dir(ltr) {
	margin-left: 10px;
}

dir

The dir option allows you presume a direction in your CSS. By default, this is not specified and you are required to include a direction [dir] attribute somewhere in your HTML, preferably on the html element.

postcssDirPseudoClass({ dir: 'ltr' });
article h3:dir(rtl) {
	margin-right: 10px;
}

article h3:dir(ltr) {
	margin-left: 10px;
}

/* becomes */

[dir="rtl"] article h3 {
	margin-right: 10px;
}

html:not([dir="rtl"]) article h3 {
	margin-left: 10px;
}
postcssDirPseudoClass({ dir: 'rtl' });
article h3:dir(rtl) {
	margin-right: 10px;
}

article h3:dir(ltr) {
	margin-left: 10px;
}

/* becomes */

html:not([dir="ltr"]) article h3 {
	margin-right: 10px;
}

[dir="ltr"] article h3 {
	margin-left: 10px;
}

shadow

The shadow option determines whether the CSS is assumed to be used in Shadow DOM with Custom Elements.

postcssDirPseudoClass({ shadow: true })
article h3:dir(rtl) {
	margin-right: 10px;
}

article h3:dir(ltr) {
	margin-left: 10px;
}

/* becomes */

:host-context([dir="rtl"]) article h3 {
	margin-right: 10px;
}

:host-context([dir="ltr"]) article h3 {
	margin-left: 10px;
}
版本列表
10.0.0 2026-01-14
9.0.1 2024-10-23
9.0.0 2024-08-03
8.0.1 2023-12-15
8.0.0 2023-07-03
7.0.2 2023-02-06
7.0.1 2023-01-28
7.0.0 2023-01-24
6.0.5 2022-07-08
6.0.4 2022-02-05
6.0.3 2022-01-12
6.0.2 2022-01-02
6.0.1 2021-12-13
6.0.0 2021-09-17
5.0.0 2018-09-18
4.0.0 2018-05-08
3.0.0 2018-03-21
2.1.0 2017-09-19
2.0.0 2017-07-25
1.1.0 2017-06-02
1.0.0 2017-06-01