<bdi>: 書字方向分離要素

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since January 2020.

<bdi>HTML の要素で、ブラウザーの書字方向アルゴリズムにこのテキストが周囲のテキストから独立しているものと扱うよう指示します。これは特に、ウェブサイトがテキストを動的に挿入するとき、挿入されるテキストの書字方向が不明な場合に便利です。

試してみましょう

双方向のテキストとは、文字の並びが左から右(左書き、LTR)のものと、右から左(右書き、RTL)のものの両方を含むテキストであり、英語の文字列の中に埋め込まれたアラビア語の引用などがあります。ブラウザーはこれを扱うために、 Unicode Bidirectional Algorithm を実装しています。このアルゴリズムでは、文字には暗黙の書字方向が与えられます。例えば、ラテン文字は左書きとして扱われるのに対し、アラビア文字は右書きとして扱われます。その他の一部の文字(空白や一部の区切り文字など)は中立として扱われ、周囲の文字に従って書字方向が割り当てられます。

ふつう、書字方向アルゴリズムは特別なマークアップを行わずに正しく動作しますが、時々、アルゴリズムが助けを必要とすることがあります。これが <bdi> の出番です。

<bdi> 要素はテキストの区間を囲んで、書字方向アルゴリズムにこのテキストが周囲から独立していることを指示します。これは 2 通りに動作します。

  • <bdi> で囲まれたテキストの書字方向は、周囲のテキストの書字方向に影響を与えない
  • <bdi> で囲まれたテキストの書字方向は、周囲のテキストの書字方向から影響を受けない

例えば、以下のようなテキストを想定してください。

EMBEDDED-TEXT - 1st place

EMBEDDED-TEXT が左書きである場合、これは正しく動作します。しかし、EMBEDDED-TEXT が右書きである場合は、- 1 は右書きのテキストとして扱われます(中立または弱い文字で構成されているためです)。結果は次のように混乱します。

1 - EMBEDDED-TEXTst place

さらに、 EMBEDDED-TEXT の書字方向が分かる場合は、dir 属性のついた <span>EMBEDDED-TEXT を囲むことでこの問題を修正できます。しかし、書字方向が分からない場合は - 例えば、 EMBEDDED-TEXT がデータベースから読み込まれたり、ユーザーに入力されたりするものであれば - <bdi> を使用して、 EMBEDDED-TEXT の書字方向が周囲に影響されることを防ぐべきです。

同様の視覚効果は、 CSS の unicode-bidi: isolate<span> またはその他の文字書式のための要素に付けることで達成できますが、これは意味が含まれず、ブラウザーは CSS の整形を無視することが許されているので、 HTML ではこのアプローチを使用しないでください。

<span dir="auto"> に囲まれた文字は、 <bdi> を使用するのと同様の効果が得られますが、意味論的には不明確になります。

属性

この要素は、他のすべての HTML 要素と同様にグローバル属性に対応していますが、 dir 属性の挙動が通常とは異なります。初期値は auto であり、親要素から値を継承しないことを示します。つまり、 dirrtl または ltr のどちらかの値を指定しない限り、ユーザーエージェント<bdi> の内容に基づいて正しい方向を特定します。

bdi がなく左書きのみの場合

この例では、競争の勝者を <span> のみを使用して列挙しています。名前は左書きのテキストのみが入れば、見栄えが良い結果になります。

html
<ul>
  <li><span class="name">Henrietta Boffin</span> - 1st place</li>
  <li><span class="name">Jerry Cruncher</span> - 2nd place</li>
</ul>

bdi がなく右書きを含むテキストの場合

この例では、競争の勝者を <span> のみを使用して列挙しており、右書きのテキストから成る名前を含んでいます。この場合、右書きの名前を入れると、書字方向が中立または弱い文字で構成された "- 1" の部分は、右書きのテキストの書字方向に合わられ、結果が混乱してしまいます。

html
<ul>
  <li><span class="name">اَلأَعْشَى</span> - 1st place</li>
  <li><span class="name">Jerry Cruncher</span> - 2nd place</li>
</ul>

bdi を使用した左書きと右書きのあるテキストの場合

この例では、競争の勝者を <bdi> を使用して列挙しています。これらの要素がブラウザーに、名前を埋め込み先のコンテキストから分離することを指示するので、例の出力は正しく並べられます。

html
<ul>
  <li><bdi class="name">اَلأَعْشَى</bdi> - 1st place</li>
  <li><bdi class="name">Jerry Cruncher</bdi> - 2nd place</li>
</ul>

技術的概要

コンテンツカテゴリー フローコンテンツ, 記述コンテンツ, 知覚可能コンテンツ
許可されている内容 記述コンテンツ
タグの省略 なし。開始タグと終了タグの両方が必須です。
許可されている親要素 記述コンテンツ を受け入れるすべての要素
暗黙の ARIA ロール 対応するロールなし
許可されている ARIA ロール すべて
DOM インターフェイス HTMLElement

仕様書

Specification
HTML Standard
# the-bdi-element

ブラウザーの互換性

BCD tables only load in the browser

関連情報