Combobox
株式会社オロ 諏訪 重貴
2024-05-24
独自実装
アクセシビリティ
data:image/s3,"s3://crabby-images/d32d1/d32d17733a6373015d2ff2d474fd07b60845e011" alt=""
SUWA Shigeki
Comboboxエンジニア
兼
Webフロントエンドエンジニア
data:image/s3,"s3://crabby-images/bb12f/bb12fe510d0aaeb96d4d924a44968ba54a6068d9" alt=""
Combobox
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
<select>
https://catnose.me/learning/html/select-option
CSSで変えられる➔
CSSで変えられない➔
data:image/s3,"s3://crabby-images/20705/20705a8a37442dbf6faa82e22581d799fe6bdaa3" alt=""
独自Combobox
作るしかねえ
独自Comboboxに
必要なもの
見た目が良い
他は<select>と同じ
<select>と同じ?
マウス操作
キーボード操作
WAI-ARIA
1.WAI-ARIAに従う
2.キーボード操作
ピックアップ
アクセシビリティ仕様
data:image/s3,"s3://crabby-images/0186a/0186a8d61eb477c75f69cfae12a28f8f21699c1e" alt=""
MDN
に大体書いてある
https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/combobox_role
どうやっていくか?
data:image/s3,"s3://crabby-images/fdb43/fdb43f168579f23c198420061de4be4e6a3ec017" alt=""
実際の実装
を参考にしてみる
https://primereact.org/dropdown/
UIライブラリ PrimeReact の <Dropbox>
よくわからない?
1.WAI-ARIAに従う
アクセシビリティ仕様
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
まずrole属性を確認
role="combobox"
role="listbox"
role="option"
role="option"
role="option"
comboboxのaria-*属性
① aria-expanded
② aria-haspopup
③ aria-controls
④ aria-activedescendant
① aria-expanded
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
aria-expanded="true/false"
listboxの開閉状態
② aria-haspopup
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
何がexpandedなのか?
listbox
tree
grid
dialog
今回はlistbox
aria-haspopup="listbox"
③ aria-controls
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
どれがexpandedなのか?
id="xxx"
aria-controls="xxx"
④ aria-activedescendant
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
端的に言うと
「サブフォーカス」
↑document.activeElement
id="a"
id="b"
id="c"
id="d"
aria-activedescendant="a"
optionのaria-*属性
① aria-selected
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
① aria-selected
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
listbox中の
どれが選択済み?
aria-selected="true"
aria-selected="false"
aria-selected="false"
aria-selected="false"
必要な状態管理
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
value / aria-selected
現在選択中の値
aria-expanded
listboxの表示状態
aria-activedescendant
「サブフォーカス」
2.キーボード操作
MDNの説明
上下矢印とEnterについて
記述アリ
data:image/s3,"s3://crabby-images/1ea6d/1ea6dfad8b1f7dea523f0024ac7ec8ad0e79a993" alt=""
ARIA: combobox role
実際の<select>
Enter/Spaceでlistboxを開く
上下矢印で「サブフォーカス」の切り替え
Enter/Spaceで選択肢を決定
マウスホバー時にも切り替え
Escで選択肢を決定せずlistboxを閉じる
Tabは効かない
combobox外をクリックでも閉じる
data:image/s3,"s3://crabby-images/8788d/8788db38bae7fd4817cebe8a9a5b400860de54af" alt=""
全部
実装する
ここまでやって
ようやく完成
data:image/s3,"s3://crabby-images/1ed56/1ed5688bb47c52c0cdbd905975c9d4ae58b91a51" alt=""
おつかれさまでした
最後に、良し悪しの確認
実際に読み上げ機能オン
<select>と比較
DevToolsのA11y Tree
実際にキーボード操作
ご清聴
ありがとう
ございました
独自実装Comboboxアクセシビリティ
By Shigeki Suwa
独自実装Comboboxアクセシビリティ
- 203