<select>: HTML 選択要素
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
* Some parts of this feature may have varying levels of support.
<select>
は HTML の要素で、選択式のメニューを提供するコントロールを表します。
試してみましょう
上の例は、典型的な <select>
の利用方法を示しています。アクセシビリティのために、 <label>
と結び付けられるように id
属性が与えられています。それぞれのメニューの選択肢は、 <select>
の中の <option>
要素で定義されます。
それぞれの <option>
要素は、選択肢が選択されたときにサーバーに送信するデータの値を含む value
属性を持ちます。 value
属性が含まれない場合、既定で要素の中に含まれるテキストの値が使用されます。 <option>
要素に selected
属性を付けることで、ページが最初に読み込まれたときに既定で選択状態にすることができます。
<select>
要素は JavaScript では HTMLSelectElement
オブジェクトで表され、このオブジェクトの value
プロパティは、選択された <option>
の値を持っています。
<select>
要素は、複数の選択肢を選択することができるかどうかを定める multiple
、同時にいくつの選択肢を表示することができるかを定める size
など、制御のために利用することができる固有の属性がいくつかあります。 required
, disabled
, autofocus
, などのような一般のフォーム入力属性の多くも受け付けます。
さらに、 <option>
要素を <optgroup>
要素の中に入れることで、ドロップダウンの中で選択肢をグループに分割することができます。また、<hr>
要素を含めることで、選択肢間に視覚的な区切りを追加することができます。
その他の例は、ネイティブフォームウィジェット: ドロップダウンコンテンツを参照してください。
属性
この要素はグローバル属性を持ちます。
autocomplete
-
文字列で、ユーザーエージェントの自動補完機能のヒントを提供します。値の完全なリストや自動補完の使い方の詳細は、 HTML の autocomplete 属性を参照してください。
autofocus
-
論理属性で、ページが読み込まれた時にこのフォームコントロールが入力フォーカスを持つべきであることを指定することができます。文書内で
autofocus
属性を持つことができるフォーム要素は一つだけです。 disabled
-
論理属性で、ユーザーがそのコントロールを利用することができないことを示します。もしこの属性が指定されていない場合、コントロールはその設定を親要素、例えば
<fieldset>
要素から継承します。もし親要素にdisabled
属性を持つものがなければ、そのコントロールは利用可能です。 form
-
<select>
を関連付ける<form>
要素(フォームオーナー)です。この属性の値は、同じ文書内の<form>
要素のid
でなければなりません。(この属性が設定されていない場合は、<select>
はその祖先である<form>
が存在すればそれと関連付けられます。)この属性によって、
<select>
要素は、<form>
要素の子孫に限らず、文書内のどこの<form>
と結び付けることもできます。これは祖先の<form>
を上書きすることもできます。 multiple
-
論理属性で、リストの複数の選択肢を選択することができることを示します。指定されていない場合は、一度に選択することができる選択肢は一つだけです。
multiple
が指定されている場合、多くのブラウザーは単一行のドロップダウンの代わりに、スクロールするリストボックスを表示します。 name
-
この属性は、コントロールの名前を指定するために使用します。
required
-
論理属性で、空ではない文字列の値の選択肢を選択しなければならないことを示します。
size
-
コントロールがスクロールするリストボックスとして表示される場合(つまり、
multiple
が指定されている場合)、この属性は一度に見えるべきリストの行数を表します。ブラウザーは、 select 要素をスクロールリストボックスとして提供する必要はありません。既定値は0
です。メモ: HTML 仕様書によると、 size 属性の初期値は
1
であるべきとされています。しかしながら、実際のところは、このことによっていくつかのウェブサイトを壊してしまうことがわかり、他のブラウザーでも現在そうしているものはなく、 Mozilla は当分の間、 Firefox でも0
を返し続けることを選択しました。
使用上の注意
複数の項目の選択
デスクトップコンピューターでは、 <select>
要素に multiple
属性がついている場合に、複数の項目を選択する方法がいくつもあります。
マウスを使用すると、 Ctrl、Command、Shift キー(オペレーティングシステムによって異なります)を押しながらクリックすることで、複数の項目を選択または解除することができます。
警告: キーボードから連続していない複数の項目を選択する仕組みは、今のところ Firefox でしか動作しないようです。
macOS では、 Ctrl + ↑ および Ctrl + ↓ のショートカットが、 OS 既定の Mission Control および Application windows のショートカットと競合するため、動作させるためにはこれらをオフにしなければならないでしょう。
キーボードを使用して、連続した複数の項目を選択するには以下のようにします。
-
<select>
要素にフォーカスを移動します(例えばTab
を使用して)。
-
↑
および
↓
のカーソルキーを使用して、項目を上下に移動し、選択したい範囲の先頭または末尾の項目を選択する。
-
Shift
キーを押したまま
↑
および
↓
のカーソルキーを使用して、項目を選択する範囲を増加または減少させる。
キーボードを使用して、連続していない複数の項目を選択するには以下のようにします。
-
<select>
要素にフォーカスを移動します(例えばTab
を使用するなど)。
-
Ctrl
キーを押したまま
↑
および
↓
のカーソルキーを使用して「フォーカスのある」選択肢を、選択したいものに移動します。「フォーカスのある」選択肢は、キーボードでリンクをフォーカスしたときと同様に、点線の輪郭線で強調されます。
-
スペース
を押して「フォーカスのある」選択肢を選択または解除します。
CSS のスタイル付け
<select>
要素は、 CSS を使って生産的にスタイル付けすることが困難です。他の要素のように、特定の側面で影響を与えることはできます。例えば、ボックスモデルや表示されるフォントを操作したり、 appearance
プロパティを使用してシステムの既定の appearance
を削除したりすることができます。
しかし、これらのプロパティはブラウザー間で一貫した結果が得られませんし、異なる種類のフォーム要素を互いに一列に並べたりするのは困難なことです。 <select>
要素の内部構造は複雑で、制御するのは困難です。完全に制御したいのであれば、スタイル付けをするのに優れた機能を備えたライブラリーを使用するか、非意味的要素や JavaScript や WAI-ARIA をを使用して独自のドロップダウンメニューを実装することを検討してください。
<select>
のスタイル付けについてのさらなる有益な情報は、以下を参照してください。
- HTML フォームのスタイル付け
- HTML フォームの高度なスタイル付け
field-sizing
プロパティは、<select>
要素が格納する選択肢との相対的なサイズを決めるかを制御します。
アクセシビリティ
<select>
内の <hr>
は、純粋に装飾的なものとみなすべきです。なぜなら、現在、アクセシビリティツリー内に公開されておらず、支援技術にも公開されていないからです。
例
基本的な select
以下の例では、とても簡単なドロップダウンメニューを生成し、既定で 2 番目の選択肢を選択状態にしておきます。
<!-- 最初に 2 番目の値が選択されます。 -->
<select name="choice">
<option value="first">1 番目の値</option>
<option value="second" selected>2 番目の値</option>
<option value="third">3 番目の値</option>
</select>
結果
グループ化された選択肢付きの select
次の例では、ドロップダウンメニューをグループ化つきで作成し、<optgroup>
と <hr>
を使用して、ドロップダウン内のコンテンツをユーザーが理解しやすくしています。
<label for="hr-select">好きな食べ物</label> <br />
<select name="foods" id="hr-select">
<option value="">食べ物を選んでください</option>
<hr />
<optgroup label="果物">
<option value="apple">りんご</option>
<option value="banana">バナナ</option>
<option value="cherry">さくらんぼ</option>
<option value="damson">ダムソンプラム</option>
</optgroup>
<hr />
<optgroup label="野菜">
<option value="artichoke">アーティチョーク</option>
<option value="broccoli">ブロッコリー</option>
<option value="cabbage">キャベツ</option>
</optgroup>
<hr />
<optgroup label="肉">
<option value="beef">牛肉</option>
<option value="chicken">鶏肉</option>
<option value="pork">豚肉</option>
</optgroup>
<hr />
<optgroup label="魚">
<option value="cod">タラ</option>
<option value="haddock">コダラ</option>
<option value="salmon">鮭</option>
<option value="turbot">カレイ</option>
</optgroup>
</select>
結果
高度な複数選択の機能
以下の例はもっと複雑で、 <select>
要素で使用できる機能をもっと示しています。
<label>
Please choose one or more pets:
<select name="pets" multiple size="4">
<optgroup label="4-legged pets">
<option value="dog">Dog</option>
<option value="cat">Cat</option>
<option value="hamster" disabled>Hamster</option>
</optgroup>
<optgroup label="Flying pets">
<option value="parrot">Parrot</option>
<option value="macaw">Macaw</option>
<option value="albatross">Albatross</option>
</optgroup>
</select>
</label>
結果
次のことが分かるでしょう。
multiple
属性を入れてあるので、複数の選択肢を選択することができます。size
属性は、同時に 4 行だけ表示できるようにします。スクロールしてすべての選択肢を表示することができます。<optgroup>
を入れることで、選択肢を複数のグループに分割しています。これは純粋に視覚的なグループ化であり、視覚表現は通常、太字のグループ名と字下げした選択肢で構成されます。- "Hamster" の選択肢には
disabled
属性が入っているので、選択することができません。
技術的概要
コンテンツカテゴリー | フローコンテンツ、記述コンテンツ、対話型コンテンツ、リスト化、ラベル付け可能、リセット可能、及びサブミット可能なフォーム関連要素 |
---|---|
許可されている内容 |
0 個以上の <option> 要素、<optgroup> 要素、<hr> 要素。
|
タグの省略 | なし。開始タグと終了タグの両方が必須です。 |
許可されている親要素 | 記述コンテンツを受け入れるすべての要素 |
暗黙の ARIA ロール |
multiple 属性がなく、 1 よりも大きい
size 属性がないならば
combobox 、それ以外の場合は
listbox
|
許可されている ARIA ロール |
multiple 属性がなく、 1 よりも大きい
size 属性がないならば
menu 、それ以外の場合は許可されている
role はなし
|
DOM インターフェイス | HTMLSelectElement |
仕様書
Specification |
---|
HTML Standard # the-select-element |
ブラウザーの互換性
BCD tables only load in the browser
関連情報
<select>
で発生するイベント:change
,input
<option>
要素<optgroup>
要素