ホームページ > ウェブフロントエンド > CSSチュートリアル > CSS BEM 命名規則とは何ですか? BEM 命名規則の概要 (詳細)

CSS BEM 命名規則とは何ですか? BEM 命名規則の概要 (詳細)

不言
リリース: 2018-07-27 17:04:07
オリジナル
4346 人が閲覧しました

BEM は、block、element、modifier の略語で、非常に便利な命名規則です。これにより、フロントエンド コードが理解しやすくなり、より厳密になります。次に、特定の bem 命名規則を見てみましょう。

1 BEM 命名規則とは何ですか?

Bem は、ブロック、要素、修飾子の略語で、Yandex チームによって提案されたフロントエンド CSS 命名方法です。

BEM は、シンプルで非常に便利な命名規則です。フロントエンド コードを読みやすく理解しやすく、共同作業しやすく、制御しやすく、より堅牢かつ明確で、より厳密なものにします。

1.1 BEM 命名パターン

BEM 命名規則のパターンは次のとおりです:

.block {}
.block__element {}
.block--modifier {}
ログイン後にコピー

  • ブロックは、より高いレベルの抽象化またはコンポーネントを表します。

  • block__element は .block の子孫を表し、全体として完全な .block を形成するために使用されます。

  • block -- 修飾子は、.block の異なる状態または異なるバージョンを表します。

1 つの代わりに 2 つのハイフンとアンダースコアを使用すると、独自のブロックを 1 つのハイフンで区切ることができます。例:

.sub-block__element {}
.sub-block--modifier {}
ログイン後にコピー

1.2 BEM 命名法の利点

BEM の鍵は、より多くの説明とより明確な構造を得ることができ、その名前から特定のマークの意味を知ることができることです。したがって、HTMLコード内のclass属性を見ることで要素間の関係を知ることができます。

従来の命名法の例:

<p class="article">
    <p class="body">
        <button class="button-primary"></button>
        <button class="button-success"></button>
    </p>
</p>
ログイン後にコピー

この書き方では、DOM構造やクラス命名から各要素の意味は理解できますが、本当の階層関係を明確にすることはできません。 CSS を定義するときは、コンポーネント間のスタイル汚染を避けるために、階層セレクターに依存して制約範囲を制限する必要もあります。

BEM 命名方法を使用した例:

<p class="article">
    <p class="article__body">
        <p class="tag"></p>
        <button class="article__button--primary"></button>
        <button class="article__button--success"></button>
    </p>
</p>
ログイン後にコピー

BEM 命名方法を使用すると、モジュールの階層関係がシンプルかつ明確になり、CSS を記述するときに多くの階層を選択する必要がなくなります。

2 BEM 命名の使用方法

2.1 BEM 形式をいつ使用するべきか

BEM を使用する際のコツは、いつ、何を BEM 形式で記述すべきかを知る必要があることです。

すべての場所で BEM 命名を使用する必要があるわけではありません。 BEM 形式は、明示的なモジュール関係が必要な場合に使用する必要があります。

たとえば、パブリック スタイルが 1 つしかない場合、BEM 形式を使用する意味はありません:

.hide {
    display: none !important;
}
ログイン後にコピー

2.2 CSS プリプロセッサで BEM 形式を使用する

BEM の欠点の 1 つは、命名方法が長くて醜いし、文章も洗練されていない。 BEM 形式がもたらす利便性と比較して、客観的に見る必要があります。

さらに、CSSは一般的にLESS/SASSなどのプリプロセッサ言語を使用して記述されており、その言語機能を使用して記述する方がはるかに簡単です。

例として挙げます:

.article {
    max-width: 1200px;

    &__body {
        padding: 20px;
    }

    &__button {
        padding: 5px 8px;

        &--primary {background: blue;}
        &--success {background: green;}
    }
}
ログイン後にコピー

2.3 人気のあるフレームワークのコンポーネントでBEM形式を使用する

Vue.js / React / Angularなどの現在人気のあるフロントエンドフレームワークには、CSSコンポーネントがありますレベル スコープのコンパイルと実装の基本原則は、CSS 属性セレクター機能を使用して、コンポーネントごとに異なる属性セレクターを生成することです。

このローカル スコープの書き込み方法を選択すると、小規模なコンポーネントでは、BEM 形式はそれほど重要ではないように見えるかもしれません。ただし、パブリックおよびグローバル モジュール スタイル定義の場合は、引き続き BEM 形式を使用することをお勧めします。

さらに、一般にスタイルのカスタマイズを目的として外部にリリースされたパブリック コンポーネントの場合、このローカル スコープ メソッドはコンポーネント スタイルの定義には使用されません。このような場合にも、BEM 形式の使用が役立ちます。

2.4 .block__el1__el2 形式を避ける

深くネストされた DOM 構造では、長すぎるスタイル名の定義は避けるべきです。

3 概要

BEM で最も難しい部分の 1 つは、スコープの開始位置と終了位置、およびスコープをいつ使用するかどうかを把握することです。使い続けて経験を積むと、徐々に使い方が分かり、これらの問題は問題なくなります。良い技術も悪い技術もありません。正しい技術だけが最善です。

関連する推奨事項:

BEM 構文の詳細な説明

[英語] BEM を使用して CSS コードをモジュール化する_html/css_WEB-ITnose

以上がCSS BEM 命名規則とは何ですか? BEM 命名規則の概要 (詳細)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート