useTextDirection
跟蹤文字排列方向
useTextDirection 管理 HTML 元素的文字方向(dir 屬性),支援 "ltr"(從左到右)、"rtl"(從右到左)和 "auto" 值。它回傳一個元組,包含當前方向值和設定函式。預設情況下在 <html> 元素上設定方向,但可以透過選擇器指定其他目標元素。
使用場景
- 為多語言應用程式動態切換文字方向(例如阿拉伯語、希伯來語使用 RTL)
- 根據使用者選擇的語言自動調整 UI 佈局方向
- 在特定區域中為混合方向文字提供正確的顯示
注意事項
- SSR 安全:在伺服器端渲染時回傳
initialValue(預設:"ltr")和空操作設定函式。伺服器上不會存取document。 - 目標選擇器:預設情況下,此 hook 在
<html>元素上設定dir。使用selector選項可針對特定元素進行範圍內的方向變更。 - 相關 hooks:另請參閱
usePreferredLanguages偵測使用者的語言偏好,這可以為文字方向選擇提供參考。
Usage
Live Editor
function Demo() { const [dir, setDir] = useTextDirection({ selector: "#_useTextDirectionDemo", }); const text = useMemo( () => dir === "ltr" ? "這個段落是英文,正確地從左到右。" : "這個段落是英文,但錯誤地從右到左。", [dir], ); const handleOnClick = () => { const value = dir === "rtl" ? "ltr" : "rtl"; setDir(value); }; return ( <div id="_useTextDirectionDemo"> <p>{text}</p> <button onClick={handleOnClick}> <span>{dir?.toUpperCase()}</span> </button> <span>點擊以更改方向</span> </div> ); }; render(<Demo/>)
Result
API
useTextDirection
Returns
readonly [UseTextDirectionValue, (value: UseTextDirectionValue) => void]: 包含以下元素的元組:
- 文字方向。
- 更新文字方向值的函數。
Arguments
| 參數名 | 描述 | 類型 | 預設值 |
|---|---|---|---|
| options | 可选参数 | UseTextDirectionOptions | undefined | - |
UseTextDirectionOptions
| 參數名 | 描述 | 類型 | 預設值 |
|---|---|---|---|
| selector | 适用于目标元素的 CSS 选择器 | string | 'html' |
| initialValue | 初始值 | UseTextDirectionValue | 'ltr' |
UseTextDirectionValue
Type
export type UseTextDirectionValue = 'ltr' | 'rtl' | 'auto'