ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
bdi 要素とは
<bdi>(Bi-Directional Isolation)は HTML5 で導入された双方向テキストを周囲のテキストから分離する要素です。アラビア語やヘブライ語のような右から左(RTL)方向のテキストを、英語や日本語のような左から右(LTR)のテキストの中に埋め込むときに、文字の並びが期待通りにならない問題を解決します。
なぜ必要か — 双方向テキストの問題
HTML は Unicode の双方向アルゴリズム(UBA)に従ってテキストを表示します。RTL 言語の文字列が LTR 文脈に混入すると、句読点や数字の位置が乱れます。ユーザー名やタイトルのように方向が事前にわからない動的データでは特に問題になります。
<!-- bdi なし -- アラビア語の username で順序が崩れることがある -->
<p>ユーザー: ابو علي - 投稿数 123</p>
<!-- bdi で囲むと、周囲は LTR、内側は RTL として安全に分離 -->
<p>ユーザー: <bdi>ابو علي</bdi> - 投稿数 123</p>
基本構文
<ul>
<li>1位 <bdi>太郎</bdi>: 1024点</li>
<li>2位 <bdi>ابو علي</bdi>: 980点</li>
<li>3位 <bdi>שלום</bdi>: 870点</li>
<li>4位 <bdi>Smith</bdi>: 850点</li>
</ul>
上記の例では、ユーザー名がアラビア語・ヘブライ語でも、点数を含む周囲の文字列の並びは LTR のまま保たれます。
属性
| 属性 | 意味 | デフォルト |
|---|---|---|
dir | テキスト方向を強制(ltr / rtl / auto) | auto(内容から自動判定) |
他の要素の dir 属性のデフォルトは inherit(親から継承)ですが、<bdi> だけはデフォルトが auto です。これが分離の本質です。
<bdi> と <bdo> の違い
| 要素 | 意味 | 用途 |
|---|---|---|
<bdi> | 双方向テキストを分離 | 動的コンテンツ(ユーザー名等) |
<bdo> | テキスト方向を強制上書き | 意図的に表示方向を変える |
<!-- bdo: 方向を強制(強制的に右から左にする) -->
<bdo dir="rtl">Hello World</bdo>
<!-- 表示: dlroW olleH -->
<!-- bdi: 分離だけ、方向は内容から自動判定 -->
<bdi>Hello World</bdi>
<!-- 表示: Hello World(LTR) -->
CSS との関係
<bdi> はおおよそ次の CSS と等価です。
bdi {
unicode-bidi: isolate;
}
そのため、<span style="unicode-bidi: isolate"> でも同じ効果が得られますが、意味的に分離を示せる <bdi> の方が推奨されます。
典型ユースケース
- 掲示板・SNS のユーザー名表示: どの言語の名前でも安全に表示
- ニュースサイトの著者名: 国際記事で各国の名前を混在
- ランキング表: 多言語のニックネームを並べる
- コメント欄: 投稿者名や引用の方向が壊れない
ブラウザサポート
Chrome 16+、Firefox 10+、Safari 5.1+、Edge は全バージョンで対応。IE は非対応ですが、未対応ブラウザでも分離が効かないだけで内容は表示される(フォールバックは grace ful)ため、安心して使えます。
FAQ
Q: 普段使う必要はある?
A: 単一言語のみ扱うサイトでは不要。ユーザー投稿やコメント、人名など、方向が事前にわからない文字列を表示する場面で使います。
Q: dir="auto" を div につけても同じでは?
A: dir="auto" は方向の自動判定はしますが、分離はしません。<bdi> は方向判定+分離の両方を一度に行います。
Q: 中身が空でも意味がある?
A: 空の <bdi></bdi> 自体は意味を持ちません。常にユーザー名や動的データを内側に入れて使います。
Q: スタイルが当たらない
A: <bdi> はデフォルトで何も装飾されません。スタイルが必要なら CSS で bdi { color: ... } のように指定します。
歴史的経緯
HTML5 で双方向テキストの扱いは複雑になりました。アラビア語や日本語など複数言語のユーザー投稿が混在する SNS(Twitter、Facebook 等)の普及に伴い、テキスト方向が事前にわからない動的データを安全に表示する必要が高まり、<bdi> が標準化されました。Unicode の双方向アルゴリズム(UBA)が複雑なため、ライブラリで処理するのではなくマークアップで宣言的に解決できるのが大きなメリットです。
実装例 — SNS 風のコメント表示
<!-- 投稿者の言語が事前にわからない -->
<article>
<header>
<bdi class="author">{{ user.name }}</bdi>
<span class="meta">- 3 分前</span>
</header>
<p><bdi>{{ post.body }}</bdi></p>
</article>
関連
- bdo 要素 — テキスト方向を強制
- dir 属性 — テキスト方向を指定
- unicode-bidi (CSS) — テキスト方向の挙動を制御
- direction (CSS) — ブロック方向の指定
- Unicode 双方向アルゴリズム(UBA)
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 2026-06-22 12:19:10
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 2026-06-22 12:17:25
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?