List

List は、あるオブジェクトの集合を順序なしリスト(unordered list)または順序つきリスト(ordered list)として表示するコンポーネントです。リストは入れ子にすることもでき、順序なしと順序つきを混在させた入れ子も可能です。

1. 概要 (Overview)

説明

List は、関連する項目を縦に並べて伝えるためのもっとも基本的なコンポーネントです。項目の順序に意味がある場合は順序つきリスト(<ol>)、意味がない場合は順序なしリスト(<ul>)を使います。

リストの開始位置はデフォルトでは左から右ですが、右から左への言語の場合は反転する必要があります。

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

リンク

2. 構成要素 (Anatomy)

Container

<ol> もしくは <ul> のルート要素です。Density / Size / Background などのモディファイアを指定します。

必須/任意: 必須

Item

リストの各項目です。<li> で記述します。テキストだけでなく、他のコンポーネントを内包させることもできます。

必須/任意: 必須(1 つ以上)

3. 使い分け (Usage)

いつ使うか

  • 関連する項目を縦に並べて伝えたいとき
  • 項目が順序を持つ場合は順序つきリスト、持たない場合は順序なしリストを使う
  • 入れ子の階層構造を表現したいとき

いつ使わないか

  • 各項目がインタラクションを持つ(クリック・選択・ドラッグなど)場合は Interactive List を使う
  • Key と Value のペアを並べる場合は Description List を使う
  • 横方向に並べたいだけの場合は List ではなくレイアウト用の Grid / Container を使う

類似コンポーネントとの違い

4. バリエーション (Variants)

Tag

<ol>(順序つきリスト)もしくは <ul>(順序なしリスト)のどちらかを指定します。

Modifier class
Ordered List.in-ol
Unordered List.in-ul

Ordered List

  1. Fundamental Design Principle
  2. Product Design Principle
  3. Communication Design Principle

Unordered List

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

Density

要素間の密度を決定します。

Modifier class
Dense.-density-dense
Normal*.-density-normal
Comfort.-density-comfort

Dense

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

Normal

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

Comfort

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

Size

サイズを決定します。

Modifier class
S.-size-s
M*.-size-m
L.-size-l

S

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

M

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

L

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

Background

上下のスペースを確保するかどうかを選択できます。

Modifier class
Background.-has-background

Background

  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle
  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle
  • Fundamental Design Principle
  • Product Design Principle
  • Communication Design Principle

実装

Mixin-based

HTML
<ul class="list-component" role="list">
  <li>Fundamental Design Principle</li>
  <li>Product Design Principle</li>
  <li>Communication Design Principle</li>
</ul>
SCSS
@use '@pepabo-inhouse/components-web' as inhouse;

.list-component {
  @include inhouse.list-style(
    $options: (
      density: dense,
      list-style-type: disc,
      size: l,
    )
  );
}

Class-based

HTML
<ul class="in-ul -size-l -density-dense -has-background" role="list">
  <li>Fundamental Design Principle</li>
  <li>Product Design Principle</li>
  <li>Communication Design Principle</li>
</ul>
SCSS
@use '@pepabo-inhouse/components-web' as inhouse;

@include inhouse.list-export;

5. ステート (States)

List 自体はインタラクションを持たないため、固有のステートは持ちません。List の各項目内にリンクなどを内包する場合、そのリンクのステートに従います。

6. アクセシビリティ (Accessibility)

このコンポーネント固有のチェック項目です。コントラスト・フォーカス可視化など全コンポーネント共通の原則はアクセシビリティガイドラインを参照してください。

  • 番号(マーカー)をブラウザに自動生成させたい場合は <ol>、そうでない場合は <ul> を使う
  • 項目に紐づく番号自体が情報として永続的な意味を持つ場合(法令の条文番号など、項目の追加・削除で繰り上がると参照が壊れるもの)は <ul> を使い、番号は項目テキストの先頭に書く
  • スクリーンリーダーが項目数を読み上げられるように、CSS のリセットでリストの semantics が外れている場合は role="list" を付与する
  • 入れ子のリストは構造を素直に反映し、見た目だけのインデントで階層を表現しない

7. ライティング (Writing)

  • 各項目の文体・粒度を揃える(例: 体言止め同士、文末「です・ます」調同士)
  • 順序つきリストでは、その順序に意味があることを文脈で示す
  • リストの先頭にイントロ文を置き、リストが何を列挙しているかが明確になるようにする