--- title: slug: Web/HTML/Element/input/search tags: - Form input - Forms - HTML - HTML forms - Input Type - Reference - Search translation_of: Web/HTML/Element/input/search ---
{{HTMLElement("input")}} 要素の search
型は、ユーザーが検索クエリを入力するために設計されたテキスト入力欄です。 text
入力欄と機能的には同じですが、{{Glossary("user agent", "ユーザーエージェント")}}は別なスタイルを適用するかもしれません。
{{anch("Value", "値")}} | 検索フィールドに含まれる値を表す {{domxref("DOMString")}}。 |
イベント | {{domxref("HTMLElement/change_event", "change")}} および {{domxref("HTMLElement/input_event", "input")}} |
対応している共通属性 | {{htmlattrxref("autocomplete", "input")}}, {{htmlattrxref("list", "input")}}, {{htmlattrxref("maxlength", "input")}}, {{htmlattrxref("minlength", "input")}}, {{htmlattrxref("pattern", "input")}}, {{htmlattrxref("placeholder", "input")}}, {{htmlattrxref("required", "input")}}, {{htmlattrxref("size", "input")}} |
IDL 属性 | value |
メソッド | {{domxref("HTMLInputElement.select", "select()")}}, {{domxref("HTMLInputElement.setRangeText", "setRangeText()")}}, {{domxref("HTMLInputElement.setSelectionRange", "setSelectionRange()")}} |
{{htmlattrxref("value", "input")}} 属性は、テキスト入力欄に入力された現在のテキストの値が入っている {{domxref("DOMString")}} です。 JavaScript では {{domxref("HTMLInputElement.value")}} プロパティを使ってこれを受け取ることができます。
searchTerms = mySearch.value;
入力欄に検証の制約がない場合 (詳しくは{{anch("Validation", "検証")}}を参照)、値は任意の文字列又は空文字列 (""
) になることがあります。
型に関係なくすべての {{HTMLElement("input")}} 要素を操作する属性に加え、 search
型の入力欄は次の属性にも対応しています。
属性 | 説明 |
---|---|
{{anch("list")}} |
オプションで自動補完の定義済みの選択肢を含む <datalist> 要素の id |
{{anch("maxlength")}} |
入力欄が受け付ける最大文字数 |
{{anch("minlength")}} |
入力欄が取りうる、妥当と判断される最小文字列長 |
{{anch("pattern")}} |
妥当と判断されるために、入力欄の内容が一致する必要がある正規表現 |
{{anch("placeholder")}} |
空欄の時に入力欄に表示される入力例の値 |
{{anch("readonly")}} |
入力欄の内容を読み取り専用にするかどうかを示す論理属性 |
{{anch("size")}} |
入力欄の長さを何文字分にするかを表す数値 |
{{anch("spellcheck")}} |
入力欄でスペルチェックを有効にするかどうか、既定のスペルチェック構成を利用するかを制御する |
{{page("/en-US/docs/Web/HTML/Element/input/text", "list", 0, 1, 2)}}
ユーザーが検索フィールドに入力することができる (UTF-16 コード単位での) 最大文字数です。 0 以上の整数値である必要があります。 maxlength
が指定されていないか、無効な値が指定されていると、検索フィールドには最大文字数が設定されません。この値は minlength
の値以上である必要もあります。
フィールドに入力されたテキストの長さが UTF-16 コード単位で maxlength
の長さを超えていると、その入力欄は制約検証に失敗します。制約検証はユーザーが値を変更した場合にのみ適用されます。
ユーザーが検索フィールドに入力することができる (UTF-16 コード単位での) 最小文字数です。これは非負の整数値で、 maxlength
で指定された値以下である必要があります。 minlength
が指定されていないか、無効な値が指定されていると、検索フィールドには最小文字数が設定されません。
入力欄のテキスト値の長さが UTF-16 コード単位で minlength
の長さよりも短いと、その検索フィールドは制約検証に失敗します。制約検証はユーザーが値を変更した場合にのみ適用されます。
{{page("/ja/docs/Web/HTML/Element/input/text", "pattern-include")}}
詳細や例については{{anch("Specifying a pattern", "パターンの指定")}}を参照してください。
{{page("/ja/docs/Web/HTML/Element/input/text", "placeholder", 0, 1, 2)}}
{{page("/ja/docs/Web/HTML/Element/input/text", "readonly", 0, 1, 2)}}
{{page("/ja/docs/Web/HTML/Element/input/text", "size", 0, 1, 2)}}
{{page("/ja/docs/Web/HTML/Element/input/text", "spellcheck-include")}}
以下の標準外の属性が検索入力フィールドで利用できます。一般的な規則として、できれば使用することを避けてください。
属性 | 説明 |
---|---|
{{anch("autocorrect")}} |
入力フィールドの編集中にオートコレクトを行うかどうか。 Safari のみ。 |
{{anch("incremental")}} |
ユーザーがフィールドの値を編集している間、ライブで検索結果を更新できるように繰り返して {{event("search")}} イベントを送信するかどうか。 WebKit and Blink only (Safari, Chrome, Opera, etc.). |
{{anch("mozactionhint")}} |
入力欄を編集している間、ユーザーが Enter または Return キーを押したときに実行されるアクションを示す文字列です。これは仮想キーボードのキーに適切なラベルを特定するために使用します。 Android 版 Firefox のみ。 |
{{anch("results")}} |
以前の検索クエリのドロップダウンリストに表示されるアイテムの最大数。 Safari のみ。 |
{{page("/ja/docs/Web/HTML/Element/input/text", "autocorrect-include")}}
論理属性 incremental
は WebKit および Blink 拡張で (そのため Safari, Opera, Chrome, などで対応)、もし存在すれば、{{Glossary("user agent", "ユーザーエージェント")}}に入力をライブ検索として処理します。ユーザーがフィールドの値を編集すると、ユーザーエージェントは {{event("search")}} イベントを検索ボックスを表す {{domxref("HTMLInputElement")}} オブジェクトへ送信します。これにより、ユーザーが検索を編集するたびに、コードからリアルタイムに検索結果を更新することができます。
incremental
が指定されていない場合、 {{event("search")}} イベントはユーザーが明示的に検索を実行した時のみ (フィールドを編集中に Enter または Return キーを押すなど) 送信されます。
search
イベントは発生頻度が制限されているため、実装により定義された間隔よりも頻繁に送信されることはありません。
{{page("/ja/docs/Web/HTML/Element/input/text", "mozactionhint-include")}}
results
属性は、 Safari のみが対応していますが、数値で {{HTMLElement("input")}} 要素が本来持っている過去の検索クエリのドロップダウンメニューに表示される項目の最大数を上書きします。
値は非負の10進数でなければなりません。提供されなかった場合、または無効な値が指定された場合、ブラウザー既定の項目の最大数が使用されます。
search
型の <input>
要素は、 text
型ととても似ていますが、検索用語を扱うことに特化している点が異なります。どちらも基本的には同じ動作をしますが、ユーザーエージェントによっては既定で異なるスタイルを選択するかもしれません (そしてもちろん、サイトは独自のスタイルを適用することができます)。
<form> <div> <input type="search" id="mySearch" name="q"> <button>Search</button> </div> </form>
これは次のように表示されます。
{{EmbedLiveSample("Basic_example", 600, 40)}}
q
は検索入力に与えられる最も一般的な name
ですが、そうすることが必須ではありません。送信すると、サーバーに送信されるデータの名前と値の組は q=searchterm
となります。
入力欄に {{htmlattrxref("name", "input")}} を設定することを忘れないでください。そうしないと送信されません。
主な違いはブラウザーによる扱い方です。特筆するべき最初のことは、ブラウザーによっては×印を表示して、クリックすると簡単に検索語を削除できることです。次のスクリーンショットは Chrome のものです。
加えて、最近のブラウザーは以前ドメイン内で入力された検索用語を自動的に格納し、そのドメインの検索入力欄で従属的な検索が行われたときに、自動補完オプションに上がってくるようにする傾向があります。これは同じ又は似た検索を繰り返して行う傾向があるユーザーにとって便利です。次のスクリーンショットは Firefox のものです。
この点について、検索フォームに適用することができる有用なテクニックを見てみましょう。
{{htmlattrxref("placeholder","input")}} 属性を使用して、テキスト入力欄の内部に有用なプレイスホルダーを提供することで、何を入力すればよいかのヒントを提供することができます。次の例を見てください。
<form> <div> <input type="search" id="mySearch" name="q" placeholder="Search the site..."> <button>Search</button> </div> </form>
プレイスホルダーの表示方法を以下で確認できます。
{{EmbedLiveSample("Setting_placeholders", 600, 40)}}
検索フォームの一つの問題はアクセシビリティです。一般的なデザインの慣例では、検索フィールドにラベルがなく (虫眼鏡のアイコンや同類のものはあります)、検索フォームの目的はふつう、よく見えるユーザーにとっては配置から明らかです (この例ではよくあるパターンを示しています)。
しかし、これは、検索入力が何であるかを言葉で示していないため、読み上げソフトの利用者に混乱を引き起こす可能性があります。 ビジュアルデザインに影響を与えないこの方法の1つは、 WAI-ARIA の機能を使用することです。
<form>
フォームの role
属性の値が search
であることで、読み上げソフトがフォームが検索フォームであることをアナウンスします。aria-label
属性を使用することができます。これは読み上げソフトによって読み上げられ説明的なテキストラベルです。これは非視覚的な <label>
と同等のものです。例を見てみましょう。
<form role="search"> <div> <input type="search" id="mySearch" name="q" placeholder="Search the site..." aria-label="Search through site content"> <button>Search</button> </div> </form>
プレイスホルダーがどう表示されるかを以下で確認できます。
{{EmbedLiveSample("Search_form_labels_and_accessibility", 600, 40)}}
前回の例から見かけ上の違いはありませんが、読み上げソフトのユーザーは追加情報を得る方法があります。
注: このようなアクセシビリティ機能の詳細ついては、 Signposts/Landmarks をご覧ください。
入力ボックスの物理的な寸法は、 {{htmlattrxref("size", "input")}} 属性を使って制御することができます。これによって、テキスト入力欄が一度に表示できる文字数を指定することができます。これは要素の幅に影響し、幅をピクセル数ではなく文字数で指定することができます。例えば、この例の中では、入力欄は30文字の幅です。
<form> <div> <input type="search" id="mySearch" name="q" placeholder="Search the site..." size="30"> <button>Search</button> </div> </form>
結果はこの広い入力ボックスになります。
{{ EmbedLiveSample('Physical_input_element_size', 600, 40) }}
search
型の <input>
要素は、通常の text
入力欄と同じ検証機能が利用できます。一般に検索ボックスに検証機能を使うことはあまりないでしょう。多くの場合、ユーザーは何でも入力できますが、既存の形式のデータに対して検索を行う場合など、考慮するべきケースも多少あります。
注: HTML のフォーム検証は、入力されたデータが正しい形式であることを保証するサーバースクリプトの代用にはなりません。 HTML を調整して検証をくぐり抜けたり、完全に削除したりすることはとても簡単にできます。 HTML を完全にバイパスし、サーバーに直接データを送信することも可能です。サーバー側のコードが受信したデータの検証に失敗した場合、不適切な形式のデータ (または大きすぎるデータ、間違った種類のデータなど) がデータベースに入力された場合に災害が発生するおそれがあります。
ユーザーにとって値が妥当かそうでないかが分かりやすくなるように、フォーム要素のスタイル付けに便利な擬似クラスが利用できます。 {{cssxref(":valid")}} 及び {{cssxref(":invalid")}} です。この節では、以下の CSS を使用して入力欄の値が妥当であれば隣にチェックマークを表示し、妥当な値でなければ隣にバツ (X) マークを表示します。
input:invalid ~ span:after { content: '✖'; padding-left: 5px; position: absolute; } input:valid ~ span:after { content: '✓'; padding-left: 5px; position: absolute; }
このテクニックにはフォーム要素の後に配置される {{htmlelement("span")}} 要素も必要で、これがアイコンのホルダーとして動作します。ブラウザーによっては一部の入力型で、直後に配置されたアイコンをうまく表示できないことがあるのでこれが必要です。
入力を行わないとフォームの送信が許可されないようにするための簡単な方法として、 {{htmlattrxref("required", "input")}} 属性を使うことができます。
<form> <div> <input type="search" id="mySearch" name="q" placeholder="Search the site..." required> <button>Search</button> <span class="validity"></span> </div> </form>
input { margin-right: 10px; } input:invalid ~ span:after { content: '✖'; padding-left: 5px; position: absolute; } input:valid ~ span:after { content: '✓'; padding-left: 5px; position: absolute; }
次のように表示されます。
{{ EmbedLiveSample('Making_input_required', 600, 40) }}
加えて、何も検索用語を入力せずに送信しようとすると、ブラウザーがメッセージを表示します。以下のものは Firefox の例です。
入力欄の中に無効な異なるデータ型を持つフォームを送信しようとすれば、下記の例のように、異なるメッセージが表示されるでしょう。
{{htmlattrxref("minlength", "input")}} 属性を使用して入力された値の最小の長さ (文字数) を指定することができます。同様に、 {{htmlattrxref("maxlength", "input")}} を使用して入力された値の最大長を文字数で設定します。
以下の例では、入力値が4~8文字の長さであることが求められます。
<form> <div> <label for="mySearch">Search for user</label> <input type="search" id="mySearch" name="q" placeholder="User IDs are 4–8 characters in length" required size="30" minlength="4" maxlength="8"> <button>Search</button> <span class="validity"></span> </div> </form>
input { margin-right: 10px; } input:invalid ~ span:after { content: '✖'; padding-left: 5px; position: absolute; } input:valid ~ span:after { content: '✓'; padding-left: 5px; position: absolute; }
This renders like so:
{{ EmbedLiveSample('Input_value_length', 600, 40) }}
4文字未満でフォームを送信しようとすると、適切なエラーメッセージが表示されます (ブラウザーによって異なります)。8文字を超えて入力しようとしても、ブラウザーが許しません。
{{htmlattrxref("pattern", "input")}} 属性を使用して、入力値が妥当と判断されるために一致しなければならない正規表現を指定することができます (入力値を検証するために正規表現を使うための短期コースは正規表現による検証をご覧ください)。
例を見てみましょう。製品 ID の検索フォームを提供し、 ID はすべてが2文字の英字に続いて4桁の番号です。以下の例でそれに対応します。
<form> <div> <label for="mySearch">Search for product by ID:</label> <input type="search" id="mySearch" name="q" placeholder="two letters followed by four numbers" required size="30" pattern="[A-z]{2}[0-9]{4}"> <button>Search</button> <span class="validity"></span> </div> </form>
input { margin-right: 10px; } input:invalid ~ span:after { content: '✖'; padding-left: 5px; position: absolute; } input:valid ~ span:after { content: '✓'; padding-left: 5px; position: absolute; }
次のように表示されます。
{{ EmbedLiveSample('Specifying_a_pattern', 600, 40) }}
website-aria-roles の例ので使用した検索フォーム (ライブで見る) が良い例です。
仕様書 | 状態 | 備考 |
---|---|---|
{{SpecName('HTML WHATWG', 'input.html#text-(type=text)-state-and-search-state-(type=search)', '<input type="search">')}} | {{Spec2('HTML WHATWG')}} | 初回定義 |
{{SpecName('HTML5.1', 'sec-forms.html#text-typetext-state-and-search-state-typesearch', '<input type="search">')}} | {{Spec2('HTML5.1')}} | 初回定義 |
{{Compat("html.elements.input.input-search")}}
<input type="text">