翻訳: BEM をネストしますか?

WBOY
WBOYオリジナル
2016-12-05 13:26:271322ブラウズ

元のリンク: http://csswizardry.com/2016/11/nesting-your-bem/

この記事を始める前に、これは提案や新しい「実践ガイド」ではないと言わなければなりません。これは私自身の空想のほんの一部です。

私は [BEM](http://csswizardry.com/2013/01/mindbemding-getting-your-head-round-bem-syntax/) の擁護者および支持者です。そしてそれは何年も続いています。なんだか楽しみですね。もちろん、それは私に多くのものを与えてくれます:

* **ソフト カプセル化** これは、名前の競合を減らすのに役立ちます。
* **カスタマイズされた CSS** これは、DOM ノードが相互にどのように関係するかを理解するのに役立ちます。
* **ターゲットの選択** これは、サブツリー間の競合を軽減し、過剰なノードのキャプチャを回避するのに役立ちます。
* **管理スタイルの特殊性** これは大きなハイライトです。
* **厳格な実装規則** これにより、指定されたコンテキストの外でクラスを使用することができなくなります。

最後の点を除いては、半分しか真実ではありません...

BEM は、クラス (例: `.widget__title`) は `.widget` 内でのみ使用できることを示しています。 しかし、これはあくまで契約上の規定にすぎません。開発者は `.widget_title` を `.model` 内に配置しても、それを動作させることができます。その理由:

* 彼らはこれまで BEM を見たことがないか、BEM の実装方法を知りません
* 彼らは怠け者なので、そうすべきではないにもかかわらず、`.modal` 内で `.widget_title` スタイルを再利用できることに気付きます。そうすれば5分早く仕事を終えることができます

彼らはそれを行うことができ、彼らにとってもうまくいきます。物事は依然として正しく表示されます。 BEM は単なる規制であり、規制には全会一致の合意が必要であるため、これによって新たなエラーが発生することはありません。

これを回避するには、次のような CSS を書くことができます:

```
.widget { }

.widget .widget__title { }
``

現在、開発者は `.modal` 内で `.widget_title` を使用できません。これは、`wideget_title` を `.widget` 内に配置した場合にのみ機能するように CSS に指示したためです。今、私たちはこれらのことを施行し始めており、それが虐待を防ぐことになります。

ここには別の問題があります: ネスティング

## CSS でのネスト


私は長い間、CSS でのネストは悪いことだと [積極的に主張](http://cssguidelin.es/#specity) してきました。その理由は次のとおりです。

* 機能の追加 (これらは常に管理する必要があります);
* 保管場所への依存の導入 (柔軟性のないシステムの兆候) ;
* 移植性の低下 (つまり、自由に移動できない);
* 脆弱性の増加ネストすると、間違ったセレクターが発生する可能性が高くなります)。

要約すると、[CSS セレクターは短くする](http://csswizardry.com/2012/05/keep-your-css-selectors-short/)。

しかし、ネストされた BEM を使用する場合、ネストが真の利点をもたらすことがわかります。しかし、これらの欠陥にどう対処すればよいでしょうか?

## 特異性

一般に、常に低い特異性を維持することが重要であることに注意してください。それはまさにその通りで、素晴らしいアドバイスです。ただし、ここには私たちがよく知っているものとは少し異なります。すべてのケースで特異性を処理する必要があると人々が言うとき、彼らが実際に言いたいのは、一貫性を維持し、セレクター間の違いをほとんど持たないようにする必要があるということです。

理論的には (ただし、これは試さないでください)、アイテムの唯一のセレクターは ID セレクターであり、特異性を適切に管理できます。特異性は普遍的に高いですが、少なくともすべてが一致し、同等です。

一貫性に対処する方法について話すとき、私たちはその [特異性マップ](http://csswizardry.com/2014/10/the-specity-graph/) を参照しています。可能。

次の一連の CSS コンポーネントを見ると:

```
.nav-primary { }

.nav-primary__item { }

.nav-primary__link { }

.マストヘッド { }

.masthead__media { }

.masthead__text { }

.masthead__title { }

.サブコンテンツ { }

.sub-content__title { }

.sub-content__title--注目の { }

.sub-content__img { }
``

...それぞれのクラスがまったく同じ特異性を持っていることがわかりました。これは素晴らしいフラットな特異性プロットです:

<図>![低く平坦な特異性を示すグラフ](http://p0.qhimg.com/t01298e8f9265d223bb.png)

[大きい画像を見る](http://csswizardry.com/wp-content/uploads/2016/11/graph-specity-01.png)

これらのクラスを次のようにネストしたら:

```
.nav-primary { }

.nav-primary .nav-primary__item { }

.nav-primary .nav-primary__link { }

.マストヘッド { }

.マストヘッド .マストヘッド__メディア { }

.マストヘッド .マストヘッド__テキスト { }

.マストヘッド .マストヘッド__title { }

.サブコンテンツ { }

.sub-content .sub-content__title { }

.sub-content .sub-content__title--注目の { }

.sub-content .sub-content__img { }
``

…表示される特異性プロットは次のようになります:

<図>![特異度の変化を示すグラフ](http://p0.qhimg.com/t01afba20a956d400fc.png)

[大きな画像を表示](http://csswizardry.com/wp-content/uploads/2016/11/graph-specity-02.png)

なんと! スパイクは、プロジェクト内で非常に近いセレクター間の特異性の変動を表すため、まさに避けたいものです。

ここでは、ネストの特異性のマイナス面を視覚化していますが、それを回避できるでしょうか?実行する方法?

## 最初のクラスへのリンク

最初のクラス (ブロック) をそれ自体にリンクしたい場合は、次のようにします:

```
.nav-primary.nav-primary { }

.nav-primary .nav-primary__item { }

.nav-primary .nav-primary__link { }

.マストヘッド.マストヘッド { }

.マストヘッド .マストヘッド__メディア { }

.マストヘッド .マストヘッド__テキスト { }

.マストヘッド .マストヘッド__title { }

.サブコンテンツ.サブコンテンツ { }

.sub-content .sub-content__title { }

.sub-content .sub-content__title--注目の { }

.sub-content .sub-content__img { }
``

…副作用なしで、すべてのネストされた要素と具体的に一致させることができます:

* DOM 内のこのブロックの位置を知る必要がないため、位置の変更に基づいてその特異性を高めることはありません
* 別の要素や特定の要素やクラスには接続されていません。これは、Block クラスが依然として非常に軽量であることを意味します。

この特異性の増加は完全にそれ自体に依存しており、次のような特異性マップが表示されます。

<図>![高いが依然として横ばいの特異性を示すグラフ](http://p0.qhimg.com/t01cecef3a9​​8ac52bbf.png)

[大きい画像を見る](http://csswizardry.com/wp-content/uploads/2016/11/graph-specity-03.png)

最初の写真よりも高いですが、それでも非常に滑らかです。特異性は 2 レベル高くなりますが、それでも適切に管理されています。セレクター コンポーネントには特別な重みがありません。

## Sass で簡素化

ネストとリンクを簡単にするために、前処理を使用できます。この場合は Sass です:

Sass で通常のセレクターをネストする方法については、私たち全員がよく知っているはずです。

```

.nav-primary {

.nav-primary__item { }

.nav-primary__link { }

}

``

これは私たちが予想していた通りの結果をもたらします:

```

.nav-primary { }

.nav-primary .nav-primary__item { }

.nav-primary .nav-primary__link { }

``

しかし、最初のクラスをそれ自体に迅速かつ効果的にリンクするにはどうすればよいでしょうか?このように:

```

.nav-primary {

{&} { }

.nav-primary__item { }

.nav-primary__link { }

}

``

`{&}` を使用すると、現在のクラスをそれ自体にリンクできます。これは、ブロックのスタイル (この場合は `.nav-primary`) がすべてここにあることを意味します:

```

.nav-primary {

{&} { /* ブロック スタイル */ }

}

``

[Sassmeister についての小さな例を見てみましょう](http://www.sassmeister.com/gist/a14e5b242ee6b20932dd44df0a3d215c)

## 実際の結果

現在、セレクターの使用を実際に強制し、DOM の正しい部分から積極的にセレクターを移動した場合に、セレクターの有効化を積極的に妨げている状況にあります。これは、他の開発者が BEM の仕組みを知らなかったり、すべてが正しく見えるまでいじくり回したりする傾向のある開発者がいる環境で作業するのに役立ちます。

すべてのクラスを管理する特異性もあります (ただし、増加しています)

### 欠陥

私たちはいくつかの特殊性を追加していますが、これは一般的に常に回避するよう努めるべきものです。

## 使用例

このテクノロジーを拡張したい場合は、始める前にいくつかの主要なユースケースを特定する必要があります。最初に頭に浮かんだのはグリッド システムでした。開発者が `.grid` 親クラスに加えて `.grid__item` クラスを使用しようとしているのを何度も見かけます。したがって、このテクニックを使い始めるとしたら、ここから始めます:

``

.grid.grid { }

.grid .grid__item { }

``

## 使用するか使用しないか?

最初に述べたように、これは私が強く推奨し、実装に熱心に取り組むテクノロジーではありません。特に他の開発者が CSS をいとも簡単に悪用している環境にいる開発者のために、参考として取り上げたかっただけです。

ただし、私が言いたいのは、BEM をネストしている場合は、戻って、最初のクラスをリンクして特異性マップをフラット化してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。