ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
基本: datalist の書き方
ユーザがフォーカスすると候補リストが出ます。タイプを始めると部分一致でフィルタされます。option の value がそのまま入力欄に入ります。
label と value を分けて表示
ブラウザによって label の表示位置が違います(Chrome は右側、Firefox は下)。挙動の統一が難しいので慎重に。
各種 input type との組合せ
| type | 用途 | 備考 |
|---|---|---|
text | 汎用 | 最も一般的 |
email | 過去入力メール候補 | ブラウザの autofill と併存 |
url | URL 候補 | |
search | 検索ボックス | クリアボタンが付く |
color | カラーパレット | 16進カラーをサジェスト |
range | スライダーの目盛り | ★ datalist でティック表示 |
date / time | 日時候補 | ブラウザサポート薄め |
range のティック
動的に候補を生成(JavaScript)
const tags = ['javascript', 'java', 'python', 'php', 'rust', 'go', 'ruby'];
const dl = document.createElement('datalist');
dl.id = 'tag-list';
for (const t of tags) {
const opt = document.createElement('option');
opt.value = t;
dl.appendChild(opt);
}
document.body.appendChild(dl);
document.querySelector('input[name=tag]').setAttribute('list', 'tag-list');
非同期検索(インクリメンタル)
サーバからリアルタイム取得する場合は、入力イベントで datalist を更新します。ただし datalist は内部でさらにブラウザがフィルタするため挙動が複雑になります:
const input = document.querySelector('input[name=q]');
const dl = document.getElementById('q-list');
let timer;
input.addEventListener('input', () => {
clearTimeout(timer);
timer = setTimeout(async () => {
const q = input.value;
if (!q) return;
const res = await fetch(`/api/suggest?q=${encodeURIComponent(q)}`);
const items = await res.json();
dl.innerHTML = items.map(i => `
select との違い
| 項目 | datalist | select |
|---|---|---|
| 自由入力 | ★ 可能(リスト外も入力可) | 不可(オプション内のみ) |
| 絞り込み | タイプ時に自動フィルタ | 無し(先頭一致でジャンプのみ) |
| マルチセレクト | 不可 | 可(multiple) |
| スタイル | 不可(ブラウザ固定 UI) | 限定的に可 |
| option グループ | 不可 | 可() |
| 必須化 | required は無入力のみチェック | required + pattern |
リスト外入力を禁止したい
datalist は自由入力を許容する仕様です。「リストの値だけ受け付けたい」場合はJavaScript / pattern で追加検証が必要:
const allowed = ['北海道', '青森県', '岩手県' /* ... */];
const input = document.querySelector('input[name=pref]');
input.addEventListener('change', () => {
if (!allowed.includes(input.value)) {
input.setCustomValidity('リストから選択してください');
} else {
input.setCustomValidity('');
}
});
または HTML の pattern 属性で正規表現制限(候補が少ない場合):
アクセシビリティ
- ブラウザ標準実装なのでキーボード操作とスクリーンリーダー対応は自動。WAI-ARIA Combobox パターンとして読まれる
- iOS Safari と Android Chrome では実装が貧弱でホイール表示になることがある
- option 数が多いと(数百以上)遅くなるブラウザがある → 仮想化が無いため
label要素で input と関連付けすることは通常の input と同じく必須
モダンなオートコンプリート ライブラリ
UI を細かく制御したい場合は、WAI-ARIA Combobox を実装した React ライブラリを使うのが定石:
| ライブラリ | 特徴 |
|---|---|
downshift | ヘッドレス(UI 無し)。最大の柔軟性。Render Props / Hooks |
@headlessui/react Combobox | Tailwind 公式相当。シンプル |
react-select | マルチ / 非同期 / グルーピング対応。スタイル制御強い |
cmdk | VS Code 風コマンドパレット UI |
react-aria useComboBox | Adobe 製。アクセシビリティ最強クラス |
FAQ
Q: option の並び順は変えられる?
A: 不可。ブラウザは記述順で表示するのみ。アルファベット順にしたければ予めソートして書く。
Q: 候補の最大数は?
A: 仕様上は無制限。実際は数百で遅くなるブラウザあり。多い場合は非同期で動的生成 + 上位 20 件のみ提示する設計に。
Q: option を画像付きにしたい
A: datalist では不可。独自実装 or downshift 系ライブラリを使う。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- meter要素 / meter
- progress要素
- datalist要素でオートコンプリート候補を表示する
- input要素
- output要素
- keygen要素
人気ページ
- 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アノテーションとは
最近更新/作成されたページ
- HTML aside要素 完全ガイド(補足情報 / サイドバー / 引用 / article との違い) 2026-06-11 05:39:14
- CSS transform 完全ガイド(translate / rotate / scale / skew / 3D 変形 + GPU 加速) 2026-06-11 05:39:14
- Oracle 管理ツール完全ガイド(OUI / DBCA / SQL*Plus / OEM / Data Pump / RMAN 役割比較) 2026-06-11 05:39:14
- HTML section要素 完全ガイド(一般的なセクション / 見出し必須 / article との違い) 2026-06-11 05:39:14
- CSS 背景プロパティ完全ガイド(background-color / image / size / gradient 一括指定) 2026-06-11 05:39:14
- CSS フォント関連プロパティ完全ガイド(font-family / size / weight / 一括指定 / Web フォント) 2026-06-11 05:39:14
- HTML li要素 完全ガイド(ul / ol との関係 / value属性 / ネスト / アクセシビリティ) 2026-06-11 05:39:14
- Java 日時 API 完全ガイド(java.time / LocalDate / Instant / Duration / 旧 Date と比較) 2026-06-11 05:39:14
- Vue CLI でプロジェクト作成(npm install / vue create / npm run serve 手順 mac) 2026-06-11 05:39:14
- JAX-RS 完全ガイド(Java EE で REST API 開発 / @Path / @GET / Jersey / RESTEasy) 2026-06-11 05:39:14
- SQL DROP TABLE 完全ガイド(CASCADE CONSTRAINTS / PURGE / 復元 / Oracle・MySQL・PostgreSQL) 2026-06-11 05:35:25
- Linux chown コマンド完全ガイド(再帰 -R / グループ変更 / 数値 UID / 注意点) 2026-06-11 05:35:25
- Docker Desktop for Windows インストール完全ガイド(Hyper-V 有効化 / WSL2 / 動作確認) 2026-06-11 05:35:25
- SQL ALTER TABLE MODIFY / ALTER COLUMN(カラム定義変更を Oracle / MySQL / PostgreSQL 別に解説) 2026-06-11 05:35:25
- SQL ORDER BY 完全ガイド(昇順 / 降順 / 複数カラム / NULL 順序 / インデックス活用) 2026-06-11 05:35:25
コメントを削除してもよろしいでしょうか?