在 BEM 中附加 CSS 的所有内容都需要类名吗?

lam*_*ade 3 css less bem

由于人们仍然建议将 BEM 用于更大的项目,我想我可以试一试。但是我已经通过设置header页面的-element遇到了问题。


这是页面标题现在的样子:

<header class="header">
    <img class="header__logo" src="logo.png" alt="alt">

    <button class="header__button-toggle" type="button">Open menu</button>

    <nav class="header__nav" role="navigation">
        <ul>
            <li><a href="">Nav item A</a></li>
            <li><a href="">Nav item B</a></li>
            <li><a href="">Nav item C</a></li>
        </ul>
    </nav>
</header>
Run Code Online (Sandbox Code Playgroud)

我了解如何定义简单的元素,例如header__logoheader__button-toggle


但是,当涉及到nav-element时,我不确定该怎么做。HTML 不会改变,因为这是一种常见且广受认可的模式,我猜在 5 年内会保持不变。

现在,我不仅需要将样式应用于nav-element,还需要将样式应用于ul、thelia-elements。我该怎么做呢?

我会在 Less 中这样做:

.header {
    &__nav {
        property: value;

        ul { property: value; }
        li { property: value; }
        a { property: value; }
    }
}
Run Code Online (Sandbox Code Playgroud)

但这在 BEM 中是有效的还是 BEM 想要消除的?


我必须以这样的方式结束吗?

.header {
    &__nav {
        property: value;

        &__list { property: value; }
        &__item { property: value; }
        &__anchor { property: value; }
    }
}
Run Code Online (Sandbox Code Playgroud)

这使 HTML 非常混乱:

<nav class="header__nav" role="navigation">
    <ul class="header__nav__list">
        <li class="header__nav__item">
            <a class="header__nav__anchor" href="">Nav item A</a>
        </li>
        <li class="header__nav__item">
            <a class="header__nav__anchor" href="">Nav item B</a>
        </li>
        <li class="header__nav__item">
            <a class="header__nav__anchor" href="">Nav item C</a>
        </li>
    </ul>
</nav>
Run Code Online (Sandbox Code Playgroud)

也许有人可以帮助我理解,如何在 BEM 方面正确解决这个问题。

tad*_*uta 5

是的,您应该为需要在 CSS 中处理的每个元素分配一个类(请参阅:https : //en.bem.info/methodology/html/#binding-blocks-to-a-dom-node)。而且您不应该害怕标记中的额外字节,因为 gzip 会很好地压缩它。

但是你应该避免元素的元素(推理请参考:https : //en.bem.info/methodology/faq/#can-i-create-elements-of-elements-block__elem1__elem2)。

所以正确的标记应该是这样的:

<nav class="header__nav nav" role="navigation">
    <ul class="nav__list">
        <li class="nav__item">
            <a class="nav__anchor" href="">Nav item A</a>
        </li>
        <li class="nav__item">
            <a class="nav__anchor" href="">Nav item B</a>
        </li>
        <li class="nav__item">
            <a class="nav__anchor" href="">Nav item C</a>
        </li>
    </ul>
</nav>
Run Code Online (Sandbox Code Playgroud)

您可能还注意到navelement上有两个不同的类。这mix在 BEM 方法中被称为:https : //en.bem.info/methodology/css/#mixes