Selection: direction プロパティ
Baseline
2025
最近利用可能
May 2025以降、この機能は最新のバージョンの端末およびブラウザーで動作します。古い端末やブラウザーでは動作しないことがあります。
direction は Selection インターフェイスの読み取り専用プロパティで、現在の選択範囲の方向を表す文字列です。
この値は、ユーザーが選択範囲の境界点を指定する順序によって決まります。 たとえば、ユーザーが開始境界点をクリックし、カーソルをドラッグして、終了境界点でクリックを解除することで選択を行う場合があります。 終了境界点が開始点よりも文書内の後方に位置する場合、方向は「前方」(forward) となり、終了点が開始点よりも文書内の前方に位置する場合は「後方」(backward) となります。 ユーザーによって方向が示されていない場合、この値は「方向なし」(none) となります。たとえば、ユーザーが単語や要素をダブルクリックして選択を行った場合や、プログラムによって選択が行われた場合などがこれにあたります。
Range.selectNode() などのメソッドを使用して、選択範囲が変更されても、方向は変わりません。
値
現在の選択範囲の種類を記述する文字列。 取り得る値は以下の通りです。
例
この例では、段落内で選択されたテキストの現在の方向をログに出力することで、direction プロパティの動作を確認することができます。
HTML
この HTML は、選択可能なテキストを含む段落要素を表示するだけです。
<p id="text-box">
この段落のテキストを選択すると、選択方向を確認できます。
</p>
なお、ライブ例の作成ガイド、単一の項目をログ出力のパターンに従った、「非表示」のログ入力ボックス(および関連するコード)も用意されている点にご注意ください。
JavaScript
このコードは、direction プロパティが定義されているかどうかを確認し、定義されている場合は、selectionchange イベント のリスナーを追加します。このリスナーは、現在の選択範囲を取得し、その方向をログに出力します。
このプロパティに対応していない場合、コードはその旨をログに出力し、選択対象となるテキストを非表示にします。
const input = document.getElementById("text-box");
if ("direction" in Selection.prototype) {
document.addEventListener("selectionchange", () => {
const selection = window.getSelection();
log(`選択方向: ${selection.direction}`);
});
} else {
log("direction プロパティが定義されていません");
input.hidden = true;
}
結果
このプロパティに対応している場合は、ダブルクリックでテキストを選択し、さまざまな方向にドラッグして離してみてください。
仕様書
| 仕様書 |
|---|
| Selection API> # dom-selection-direction> |