LoginSignup
267
234

More than 3 years have passed since last update.

【命名規則】BEMを使った書き方についてまとめてみた【CSS】

Posted at

実務でCSSをガッツリ書くことになったので、復習の意を込めて自分用のチートシートを作成しました。
今回は現場でよく使われているBEMの書き方について調べたことのまとめです。

BEMとは

BEMはBlock Element Modifierの略で、CSSを設計・命名していく手法です。

  • Block: 大枠となる独立した要素
  • Element: Block中の要素
  • Modifier: BlockやElementのスタイル

保守性の高さから1番多く使われている命名規則だと思います。

BEMを使う目的

BEMは名前の衝突を避けるために考案されたCSS設計です。

保守性の高さを解決するための手法は他にもあり、HTMLはシンプルがな書き方が求められますが、まだまだ決定打に欠けています。
BEMは見た目が汚いですが、シンプルを求めて面倒な目にあうよりは、少々汚くても扱いやすいBEMが多くの現場で採用されています。

命名規則の考え方

class名の命名規則にはいくつか種類がありますが、どの命名規則を採用するにしても、前提として考えることは以下です。

  • 明確に決まっている
  • わかりやすい
  • 保守性が高い(管理しやすい)

BEM以外のOOCSSやSMACSS等の命名規則を使うとしても、上記はそもそも命名規則を考える目的になります。
手段を好き嫌いで選ばずに、その時々で最適だと思われる命名規則を採用しましょう。

BEMの命名の仕方

class名であれば以下のように命名します。

class="block__element–-modifier"

最初にBEMは以下の3つの略だと説明しました。

  • Block: 大枠となる独立した要素
  • Element: Block中の要素
  • Modifier: BlockやElementのスタイル

これらの要素を以下のルールに基づいて命名します。

  • blockとelementはアンダースコア2つで区切る
  • Elementとmodifierはハイフン2つで区切る
  • ハイフンとアンダースコアは2つ
  • block, element, modifierが複数単語になる場合、単語と単語の間はハイフン1つで区切る
  • ハイフン1つの場合はElementとModifierの区切りではなく、ただの単語の区切りとして使用

サンプルコード

以下ははBEM記法でclassを付けたサンプルです。

<section class="about">
  <div class="about__item">
    <h2 class="about__item-ttl">ここにタイトルが入る</h2>
    <p class="about__item-txt">テキストが入る。テキストが入る。</p>
    <a href="#" class="about__item-link about__item-link--red">MORE</a>
  </div>
</section>

クラス命名でよく使われる単語

以下はクラス作成時に頻出するクラス名です。
ここにないような単語はcodicなどで調べて組み合わせを考えてみましょう。

Block

単語 意味
section 区分・区画
content 文書の内容
article 記事
post 投稿
top 頂上・上部
home トップページ
sidebar 補足記事
wrapper 内包する
wrap wrapperの略語
container wrapperの類語容器・入れ物wrapperはレイアウト的に、containerは意味的に使うことが多い
group 集まり
area 特定の場所・範囲
emphasis 強調・重視
catch 興味を惹く・関心をつかむ
note 注釈
description 概要
desc descriptionの略語
introduction 前置き・導入
intro introductionの略語
announce お知らせ
information 情報
info informationの略語
action Call To Action重要度の高い
more もっと多くの
feature 主要なもの
detail 詳細・細部
summary 概要・要約

Element

BEMのElementで使われるような名詞や形容詞など。

単語 意味
inner 内側の
outer 外側の
body 主要部分
head 上部
foot 下部
heading 見出し・表題
title 表題・題名
lead 見出しの補足・記事の要約
list 一覧・表
menu 一覧・表
item (表やデータなどの)項目
unit 1つの単位・1セット
column 縦列
col columnの略語
text 本文
caption 画像・図表の補足文
thumbnail 縮小した画像
thumb thumbnailの略語
avatar 人の顔を示す画像
feature 特徴を補足する画像
tel 電話番号
address 住所
date 日付
time 日時
category 分類・部類
cat categoryの略語
tag 識別子
next 次の
previous 前の
prev previousの略語
mask 覆い隠す
overlay かぶせる・上書きする
delimiter アイテムの範囲や境界線を示すインターフェイス
separator delimiterの類語で混ぜないように分離する目的で使います
divider delimiterの類語でグルーピングするように分割する目的で使います

Modifier

単語 意味
success 成功
alert 注意・警戒
attention 配慮・気配り
error 間違い・失敗
caution 用心・警告
warning 警告・予告
danger 危険・驚異
tiny とても小さい
xs tinyの類語でExtra small(smallよりさらに小さい)こと
small 小さい
medium 中間
large 大きい
huge とても大きい
xl hugeの類語でExtra large(特大・超大型)のこと
reverse 反転する
push 前方に押す
pull 自分の方に引く
offset 相殺する・埋めあわせる
left 左側の
center 真ん中
right 右側の
top 上部
middle 真ん中
bottom 下部
round 角丸
circle 円形

分類

単語 意味
about 〜について
work 仕事・任務
product 製品
service サービス
news お知らせ・近況
event 行事・出来事
history 歴史・沿革
archive 保存・保管・記録
concept 構想・概念・考え
recommend おすすめ・推奨
table of contents 目次
toc Table of contentsの略語
index 索引・指標
contact 問い合わせ・連絡
inquiry 問い合わせ・質問・調査
access 交通手段
shop 店舗
related 関連のある
privacy 個人情報の利用・保護の方針
faq Frequently asked questionsquestions(よくある質問)の略
qanda Question and answer・Q&A・質問と回答
input フォームの入力画面
confirm フォームの確認画面
finish フォームの完了画面
search 検索する
result 検索結果画面
cart 購入するアイテムを一時的に保存する画面
checkout 保存していたアイテムを購入する画面

形容詞

名詞の性質や状態を修飾する品詞。「〜の」「〜な」。

単語 意味
main 主要な
primary 主要な
secondary 補助的な・第二の
tertiary 第三の
quaternary 第四の
common 共通の
global 全体的な
local 局所的な
general 一般的な
brand ブランドの
site サイトの

ステータス

状態を示す動詞や形容詞など。

単語 意味
show 見せる
hide 隠す
open 開く
close 閉じる
current 現在の
active 活動中・有効な
disabled 無効になっている

文字を扱う要素

単語 意味
link アンカーテキスト
label 分類する・項目名
tag 符号・識別子
badge 残数を示す数値
copyright 著作権表示
tooltip マウスオーバー時に補足情報を表示するインターフェイス
button オン・オフの選択に使うインターフェイス
btn buttonの略語

イメージ

単語 意味
image 画像
img imageの略語
icon 対象の内容や機能などを小さな絵柄で表したもの
loading 読み込み中であることを示すインターフェイス
logo 社名や製品名などを図案化・装飾化した文字・文字列
map 地図
chart 理解しやすいような方法で情報を示すリストやグラフのこと
graph chartの類語で視覚表現のための手段のこと
hero キービジュアルになる大型の画像
banner (主に宣伝用の)画像をともなうリンク
carousel 画像などのコンテンツを上下左右にスライドさせて切り替えるインターフェイス
slider carouselの類語
ticker carouselの類語で自動でアイテムを左右に流しながら表示する。ユーザーは基本的にコントロールできない
lightbox carouselの類語で、モーダルのjQueryプラグインのこと。主な用途はサムネイル画像をクリックしてモーダルを開き画像を大きく見せること

ナビゲーション

単語 意味
navigation 情報へ誘導するリンク
nav navigationの略語。
global navigation - ほとんどの画面で表示されている主要なナビゲーション
local navigation - あるカテゴリ内専用のナビゲーション。グローバルナビゲーションの中や下に配置する場合や、サイドバーに配置する場合がある
mega menu - 深い階層のカテゴリやページへのナビゲーション。ドロップダウン(クリックやマウスオーバー)で階層を表示していく。カテゴリやページ数の多いサイトのグローバルナビゲーションに使われることが多い
breadcrumb パンくずリスト。トップページから現在ページまでの階層構造を示したリンク
topicpath breadcrumbの類語
springboard 同じサイズのリンクを2×2や3×3のように配置した同じ重要度を持つ並列なナビゲーション
list menu - 縦に並んだリスト型のリンクで、階層構造をもったナビゲーション
dashboard グラフやステータスなどを一つの画面にまとめたインターフェイス
pagination 昇順にしたページ番号付きのナビゲーション
linear navigation - その画面の前後に移動するためのナビゲーション。paginationとの違いはページ指定ができないこと
back to-top - ページトップに戻るためのページ内リンク
tab 書類などのインデックスタブを模した、画面内のコンテンツ表示を切り替えるインターフェイス
tabbar おもに画面下部に固定されたタブで、画面全体を切り替えるインターフェイス
segmented control - 機能的にはtabと同じで、見た目がタブではなくボタンである点が違う
off canvas - 表示領域外から画面の大半を覆い隠したり(オーバーレイ)、ずらすようにスライドしながら表示するナビゲーション
side drawer - off-canvasの類語。drawerは「引き出し」の意味
toggle menu - 同一の操作で二つの状態を交互に切り換えるインターフェイスで、操作対象になるボタンを基準にナビゲーションを表示することが多い
sitemap サイト内のすべてのページへのリンクをリスト化したもの
sns ソーシャルネットワーキングサービス

フォーム

単語 意味
form 送信フォーム。
login ユーザー認証をするためのフォーム
signin loginの類語
logout signout - ユーザー認証を解除すること
registration ユーザー登録をするためのフォーム
signup registrationの類語
step navigation - 複数画面にわたるフォームの順序や、現在地を示したナビゲーション
search box - キーワード検索するためのフォームエリア
text field - input[type="text"]のような利用者が編集する改行なしのテキストフィールド
textarea textareaのような利用者が編集する複数行のテキストフィールド
checkbox input[type="checkbox"]のような1つ以上の項目を選択するインターフェイス
radio input[type="radio"]のような1つの項目を選択するインターフェイス
select selectのような1つの項目を選択するインターフェイス。ラジオボタンと違い、(dropdownのように)項目が最初は隠れているのが特徴
submit 送信ボタン
reset リセット(取り消し)ボタン
modify 修正ボタン

その他

単語 意味
cards トランプのような積み重なったカードのメタファーをもつインターフェイス。
dropdown 複数の項目を表示して、1つの項目を選択するインターフェイス。
pulldown dropdownの類語。
accordion 折りたたまれたコンテンツを選択することで表示させるインターフェイス。
scroll tab - 表示領域よりも横に長いナビゲーションで、左右にスクロールすることで非表示部分を見ることができるインターフェイス。
dialog (主に)注意や警告を知らせるために使用されるメッセージで、ユーザーに操作を要求するのが特徴。
toast dialogの類語で、dialogとの違いは時間が経つと自動的に消えること。
popup window - dialogの類語で、リンク先を別の小さなウィンドウで表示するインターフェイス。
toolbar ユーザーが利用できるツールやアクションをまとめたインターフェイス。
comment 記事に対する反応。
table テーブル・図表。
timeline チャットや年表のように時系列に並べたリスト。

まとめ

今回はBEMについて書きましたが、自分は割と独学で適当にやっちゃってたので、自分用のチートシートとして作成しました。

命名規則などについては他のブログやQiitaで良質な記事が大量にあるので、さらにわかりやすい記事を求める人はそちらに飛んで見ることをおすすめします!

お疲れさまでした!

参考させていただいた記事

267
234
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
267
234