跳至主要内容

max-nesting-depth

限制嵌套深度。

a { & > b { top: 0; } }
/** ↑
* This nesting */

此规则通过检查规则和 at-规则的实际“嵌套深度”与您指定的最大值来工作。 以下是嵌套深度的工作原理

a {
& b { /* nesting depth 1 */
& .foo { /* nesting depth 2 */
@media print { /* nesting depth 3 */
& .baz { /* nesting depth 4 */
color: pink;
}
}
}
}
}
注意

根级别 at-规则将**不包括**在嵌套深度计算中,因为大多数用户会认为根级别 at-规则是“免费的”(因为是必要的)。 因此,以下两个 .foo 规则的嵌套深度均为 2,因此如果您的 max 小于或等于 2,则它们将通过

a {
b { /* 1 */
.foo {} /* 2 */
}
}

@media print { /* ignored */
a {
b { /* 1 */
.foo {} /* 2 */
}
}
}

此规则将(现已弃用)插件 stylelint-statement-max-nesting-depth 的功能集成到 Stylelint 的核心。

message 次要选项 可以接受此规则的参数。

选项

int:允许的最大嵌套深度。

例如,使用 2

以下模式被视为问题

a {
& .foo { /* 1 */
&__foo { /* 2 */
& > .bar {} /* 3 */
}
}
}
a {
@media print { /* 1 */
& .foo { /* 2 */
& .bar {} /* 3 */
}
}
}

以下模式**不**被视为问题

a {
& .foo { /* 1 */
&__foo {} /* 2 */
}
}

a .foo__foo .bar .baz {}
@media print {
a {
& .foo { /* 1 */
&__foo {} /* 2 */
}
}
}

可选的次要选项

ignore: ["blockless-at-rules"]

忽略仅包装其他规则且本身没有声明块的 at-规则。

例如,使用 1

以下模式被视为问题

因为 at-规则具有声明块。

a {
&:hover { /* 1 */
@media (min-width: 500px) { color: pink; } /* 2 */
}
}
a {
@nest > b { /* 1 */
.foo { color: pink; } /* 2 */
}
}

以下模式**不**被视为问题

因为以下所有 .foo 规则的嵌套深度都只有 1。

a {
.foo { color: pink; } /* 1 */
}
@media print { /* ignored regardless of options */
a {
.foo { color: pink; } /* 1 */
}
}
a {
@media print { /* ignored because it's an at-rule without a declaration block of its own */
.foo { color: pink; } /* 1 */
}
}

ignore: ["pseudo-classes"]

忽略每个选择器列表项中的第一个选择器是伪类的规则

例如,使用 1

以下模式被视为问题

a {
b { /* 1 */
.c { /* 2 */
top: 0;
}
}
}
a {
&:hover { /* ignored */
b { /* 1 */
.c { /* 2 */
top: 0;
}
}
}
}
a {
b { /* 1 */
&::selection { /* 2 */
color: #64FFDA;
}
}
}
a {
b { /* 1 */
&:hover, .c { /* 2 */
top: 0;
}
}
}

以下模式**不**被视为问题

因为以下所有伪类规则的嵌套深度都只有 1。

a {
b { /* 1 */
&:hover { /* ignored */
top: 0;
}
}
}
a {
b { /* 1 */
&:nest {
&:nest-lvl2 { /* ignored */
top: 0;
}
}
}
}
a {
&:hover { /* ignored */
b { /* 1 */
top: 0;
}
}
}
a {
&:nest { /* ignored */
&:nest-lvl2 { /* ignored */
top: 0;
b { /* 1 */
bottom: 0;
}
}
}
}
a {
b { /* 1 */
&:hover, &:focus { /* ignored */
top: 0;
}
}
}

ignoreAtRules: ["/regex/", /regex/, "string"]

忽略指定的 at-规则。

例如,使用 1 并给出

["/^--my-/", "media"]

以下模式**不**被视为问题

a {
@media print { /* 1 */
b { /* 2 */
c { top: 0; } /* 3 */
}
}
}
a {
b { /* 1 */
@media print { /* 2 */
c { top: 0; } /* 3 */
}
}
}
a {
@--my-at-rule print { /* 1 */
b { /* 2 */
c { top: 0; } /* 3 */
}
}
}
a {
@--my-other-at-rule print { /* 1 */
b { /* 2 */
c { top: 0; } /* 3 */
}
}
}

以下模式被视为问题

a {
@import print { /* 1 */
b { top: 0; } /* 2 */
}
}
a {
@--not-my-at-rule print { /* 1 */
b { top: 0; } /* 2 */
}
}

ignorePseudoClasses: ["/regex/", /regex/, "string"]

忽略指定的伪类。

例如,使用 1 并给出

["hover", "^focus-"]

以下模式**不**被视为问题

a {
&:hover { /* ignored */
b { /* 1 */
top: 0;
}
}
}
a {
&:hover, &:active { /* ignored */
b { /* 1 */
top: 0;
}
}
}

以下模式被视为问题

a {
&:visited { /* 1 */
b { /* 2 */
top: 0;
}
}
}
a {
&:hover, &:visited { /* 1 */
b { /* 2 */
top: 0;
}
}
}

ignoreRules: ["/regex/", /regex/, "string"]

忽略与指定选择器匹配的规则。

例如,使用 1 并给出

[".my-selector", "/^.ignored-sel/"]

以下模式**不**被视为问题

a {
.my-selector { /* ignored */
b { /* 1 */
top: 0;
}
}
}
a {
.my-selector, .ignored-selector { /* ignored */
b { /* 1 */
top: 0;
}
}
}

以下模式被视为问题

a {
.not-ignored-selector { /* 1 */
b { /* 2 */
top: 0;
}
}
}
a {
.my-selector, .not-ignored-selector { /* 1 */
b { /* 2 */
top: 0;
}
}
}