ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
bdo 要素とは
<bdo> は Bidirectional Override(双方向上書き)の略です。HTML 内に書かれたテキストの表示方向 (LTR / RTL) を強制的に上書きするためのインライン要素です。
通常、ブラウザは Unicode の双方向アルゴリズムに従って「英字は左から右、アラビア語は右から左」のように自動判定して表示します。これを意図的に上書きしたいときに使うのが <bdo> です。
基本構文
<!-- 通常: 左から右に表示 -->
<p>HELLO WORLD</p>
<!-- bdo で逆順表示 -->
<p><bdo dir="rtl">HELLO WORLD</bdo></p>
<!-- 表示は: DLROW OLLEH -->
dir 属性は必須で、次の 2 値のいずれかを指定します。
| 値 | 意味 | 用例 |
|---|---|---|
ltr | Left-To-Right(左から右) | 右書きの中で一部だけ左書きにしたい |
rtl | Right-To-Left(右から左) | 左書きの中で一部だけ右書きにしたい |
典型的な利用シーン
1. 右書きテキストを意図的に左書きで見せる
アラビア語やヘブライ語の文字を、表示は左書きにしたいケース。Unicode の双方向アルゴリズムを強制的に無効化します。
<p>The word in Hebrew is <bdo dir="ltr">שלום</bdo>.</p>
2. プレゼンや問題作成での逆順表示
「文字を逆から書いたらどう見える?」のような演出に。
<p>普通: HELLO</p>
<p>逆順: <bdo dir="rtl">HELLO</bdo></p>
<!-- 表示は OLLEH -->
bdi 要素との違い
双方向テキスト関連で似た要素に <bdi> (Bidirectional Isolate) があります。性格は真逆です。
| 要素 | 動作 | 用途 |
|---|---|---|
<bdo> | 方向を強制上書き(必須の dir 属性) | 意図的に逆向き表示する |
<bdi> | 双方向アルゴリズムから分離し周囲に影響させない | ユーザー名など混在テキストでレイアウト崩れを防ぐ |
bdi の例
<!-- ユーザー名 (アラビア語) が周囲のレイアウトを崩さないように -->
<p>ユーザー: <bdi>إيان</bdi> が投稿しました。</p>
CSS direction との比較
CSS の direction プロパティでも同じ視覚効果を出せますが、意味的には別物です。
| 方法 | 性格 | 使い分け |
|---|---|---|
<bdo dir="rtl"> | HTML 意味タグ | その範囲が「双方向上書き」だと文書構造として明示 |
CSS direction:rtl | 見た目の指定 | レイアウト目的、UI のテーマ切替 |
「双方向テキスト処理の都合で方向を強制している」という意味を込めるなら <bdo>、純粋にスタイル目的なら CSS という棲み分けが基本です。
使用上の注意
dir属性は必須。値なしの<bdo>は仕様違反。- 常用するタグではない。ほとんどの場面で
<bdi>や CSS direction の方が適切。bdo は「強制上書きが本当に必要な場面」専用。 - スクリーンリーダーでは内容が逆順に読まれない場合があるため、アクセシビリティが重要な本文には不向き。
よくある質問
Q: 入力欄にユーザー名を表示するときレイアウトが崩れる
A: それは <bdo> ではなく <bdi> の出番。bdi で囲むと周囲のテキスト方向に影響を与えなくなります。
Q: 単に文字列を逆順にしたいなら JavaScript で良くない?
A: 「視覚的に逆順表示」と「文字列を逆順に変換」は別物です。bdo は表示方向の上書きであって、コピーすれば元の順序で取れます。文字列自体を反転したい場合は JS で [...str].reverse().join("") 的に処理する方が適切。
Q: bdo は SEO 的にマイナス?
A: 適切な用途で使えば問題ありません。検索エンジンは文字列をテキストとして取得するため、表示方向の上書きは順位に直接影響しません。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?