学習し、自分なりに噛み砕いて、書き出すブログ。

MindBEMding の Modifier は元のクラス名と一緒に指定するべきか否か

MindBEMding の Modifier を定義する際、単一のクラスセレクタで書く方法と、複数のクラスセレクタで書く方法があると思います。

実際の HTML で示すと以下のような感じです。

複数クラス

<table class="mod-table-01 mod-table-01--line-color-green">
  <tr>
    <th>foo</th>
    <th>bar</th>
  </tr>
  <tr>
    <td>baz</td>
    <td>foobar</td>
  </tr>
</table>

単一クラス

<table class="mod-table-02--line-color-green">
  <tr>
    <th>foo</th>
    <th>bar</th>
  </tr>
  <tr>
    <td>baz</td>
    <td>foobar</td>
  </tr>
</table>

multiple class とコメントで書かれているほうでは、クラス名は mod-table-01mod-table-01--line-color-green の二つが指定されています。

single class とコメントで書かれているほうでは、クラス名は mod-table-02--line-color-green のみ指定されています。

上記の HTML に対し、CSS でルールセットを書く場合は以下のようになると思います。

複数クラス

.mod-table-01 {
  border: 1px solid black;
  border-collapse: collapse;
  margin: 10px auto;
}
.mod-table-01--line-color-green {
  border: 1px solid green;
}

単一クラス

.mod-table-02,
.mod-table-02--line-color-green {
  border: 1px solid black;
  border-collapse: collapse;
  margin: 10px auto;
}
.mod-table-02--line-color-green {
  border: 1px solid green;
}

この二つの指定方法のうち、果たしてどちらが良いのかというのを考えたので、以下に利点と欠点を書いていきます。

HTML に単一のクラス名を指定する際の利点と欠点

利点

複数のクラスを指定するより、若干簡潔になる

MindBEMding の考えでセレクタに名前を付けた場合は名前が長くなりがちです。複数のクラス名を指定した場合は、上記で示した HTML の例を見ると分かるように冗長感が否めません。

その一方、単一のクラス名で指定した場合は、HTML 側の指定は複数のクラス名指定より、簡潔になります。

欠点

スタイル定義が複雑になる

下記の JSFiddle の例を見ると分かるのですが、単一のクラス名を指定するほうが、複数のクラス名を指定するより、スタイル定義が複雑になっています。

これは例えば、後からプロジェクトに入ってきた人が CSS ファイルで定義されている内容を見た時に、理解を妨げる原因になるのではという考えがあります。

CSS のファイルサイズが大きくなりがち

文字数 カウント(文字バイト数チェック)で測ると分かるのですが、単一のクラス名を HTML 側で指定してスタイル定義をしていく場合、複数のクラス名を HTML 側で指定するより、CSS のファイルサイズが大きくなります。

HTML に複数のクラス名を指定する際の利点と欠点

利点

スタイル定義の見通しが良くなる

再び先ほどの JSFiddle の例を引っ張り出しますが、複数のクラス名を指定する場合、単一のクラス名を指定するより CSS のルールセット定義が簡潔になっています。

欠点

HTML 上でのクラス名の指定が単一のクラスを指定するより若干冗長になる

単一のクラス名を定義する時は HTML では prefix-table-01--line-color-green とだけ class 属性の値に書けばよかったですが、複数のクラスを定義する場合は prefix-table-01 prefix-table-01--line-color-green と若干冗長になります。

結果どちらを使ったほうが良いのか

単一のクラス名を指定するほうは HTML 側が少し簡潔になりますが、複数のクラス名を指定するのと比べ CSS 側が複雑になりがちというのは先ほど書いたとおりです。

その複雑になりがちというのが自分ではあまり許容できなかったので、複数のクラス名を HTML の class 属性の値として指定して、スタイル定義をしていくのが良いかなと思いました。

他の参考記事

マルチクラス設計について物申している記事もあるので、よかったらこちらも参考にしてみてください。

CSSプリプロセッサーのextendの悪いところ - morishitter blog