<input type="search">

Елементи <input> типу search (пошук) – це текстові поля, розроблені для введення користувачами пошукових запитів. Функціонально вони ідентичні до полів text, але можуть бути оформлені інакше з боку користувацького агента.

Спробуйте його в дії

Значення

Атрибут value містить рядок, що представляє значення, вміщене в пошуковому полі. Його можна отримати в JavaScript за допомогою властивості HTMLInputElement.value.

searchTerms = mySearch.value;

Якщо на поле не накладено жодних обмежень валідації (докладніше про це в розділі Валідації), то значення може бути будь-яким рядком тексту, або порожнім рядком ("").

Додаткові атрибути

На додачу до глобальних атрибутів та атрибутів, що діють на всіх елементах <input>, незалежно від їхнього типу, пошукові поля приймають наступні атрибути.

list

Значення атрибута list – це id елемента <datalist>, розташованого в тому самому документі. <datalist> надає список наперед визначених значень, що пропонуються користувачам для поля. Всі значення в списку, несумісні з type, не включаються в список запропонованих варіантів. Ці значення подаються як пропозиції, а не вимога: користувачі можуть як обирати зі списку, так і ввести щось своє.

maxlength

Максимальна довжина рядка (в кодових одиницях UTF-16), котрий користувач може ввести в пошукове поле. Це повинно бути ціле числове значення, 0 або більше. Якщо не задано maxlength, або якщо задано недійсне значення, то пошукове поле не має максимальної довжини. Це значення також повинно бути більшим або рівним значенню minlength.

Поле не пройде валідацію обмежень, якщо довжина введеного в поле тексту перевищує maxlength кодових одиниць UTF-16 завдовжки. Валідація обмежень відбувається лише тоді, коли значення змінюється користувачем.

minlength

Мінімальна довжина рядка (в кодових одиницях UTF-16), котрий користувач може ввести в пошукове поле. Це повинно бути невід'ємне ціле числове значення, менше або рівне значенню, заданому maxlength. Якщо не задано minlength, або якщо задано недійсне значення, то пошукове поле не має мінімальної довжини.

Пошукове поле не пройде валідацію обмежень, якщо довжина введеного в поле тексту – менша за minlength кодових одиниць UTF-16 завдовжки. Валідація обмежень відбувається лише тоді, коли значення змінюється користувачем.

pattern

Атрибут pattern, коли заданий, є регулярним виразом, котрому повинно відповідати value, щоб пройти валідацію обмежень. Це повинен бути дійсний регулярний вираз JavaScript, подібний до тих, що використовуються типом RegExp, і що задокументовані в нашому посібнику з регулярних виразів; при компіляції регулярного виразу задається позначка 'u', тож патерн обробляється як послідовність кодових точок Unicode, а не як ASCII. На кінцях тексту патерну не повинно бути скісних рисок.

Якщо заданий патерн – не заданий або недійсний, то регулярний вираз не застосовується, і цей атрибут цілком ігнорується.

[!NOTE] Слід використовувати атрибут title, щоб задати текст, котрий більшість браузерів показує як підказку для пояснення того, яким вимогам повинен відповідати текст, аби відповідати патерну. Також слід додати інший пояснювальний текст поруч.

Дивіться деталі та приклад у розділі Задання патерну.

placeholder

Атрибут placeholder – це рядок, що надає користувачам стислу підказку щодо того, якого роду інформація очікується в полі. Це повинно бути слово або коротка фраза, що показує очікуваний тип даних, а не пояснювальне повідомлення. Такий текст не повинен містити повернення каретки або розриву рядка.

Якщо вміст контрольного елемента має один напрям письма (зліва направо або справа наліво), а заповнювач треба показати в іншому напрямі, то можна використати в заповнювачі символи двонапрямленого алгоритму форматування Unicode; більше інформації у статті Як використовувати контрольні символи Unicode у двонапрямленому тексті.

[!NOTE] Уникайте використання атрибута placeholder, якщо це можливо. Він є менш семантично корисним, ніж інші способи пояснення форми, і може призводити до неочікуваних технічних проблем зі вмістом. Більше інформації в підписах <input>.

readonly

Булів атрибут, котрий, якщо присутній, означає, що користувач не може редагувати поле. Проте value цього поля усе ж може бути змінено кодом JavaScript, шляхом безпосереднього присвоєння властивості value об'єкта HTMLInputElement.

[!NOTE] Оскільки таке поле не може мати значення, required не діє на поля, на котрих також задано атрибут readonly.

size

Атрибут size – це числове значення, що вказує на те, якої ширини в символах повинно бути поле введення. Значення цього атрибута повинно бути числом, більшим за нуль, а усталене значення – 20. Оскільки розмір символів буває різний, така ширина може бути, а може й не бути точною, і на її розмірність не варто покладатися; результівне поле може бути вужчим або ширшим за задану кількість символів, залежно від самих цих символів та шрифту (застосованих налаштувань font).

Це не задає обмеження того, скільки символів користувач може ввести в поле. Це лише приблизно задає те, скільки символів водночас буде видно. Аби задати верхню межу довжини введених даних, слід використовувати атрибут maxlength.

spellcheck

spellcheck – це глобальний атрибут, що використовується для позначення того, чи потрібно вмикати для елемента перевірку правопису. Він може використовуватись на будь-якому редагованому вмісті, але тут розглядається специфіка, що стосується застосування spellcheck до елементів <input>. Дозволені значення spellcheck:

false

Вимкнути перевірку правопису для цього елемента.

true

Ввімкнути перевірку правопису для цього елемента.

"" (порожній рядок) або без значення

Виконувати усталену поведінку елемента щодо перевірки правопису. Ця усталена поведінка може залежати від налаштування spellcheck батьківського елемента та інших чинників.

Поле введення може мати ввімкнену перевірку правопису, якщо не має атрибута readonly і не є вимкненим.

Значення, повернене при зчитуванні spellcheck, може не відповідати реальному станові перевірки правопису на контрольному елементі, якщо налаштування користувацького агента відкидають власне налаштування елемента.

Нестандартні атрибути

Пошуковим полям введення доступні наступні нестандартні атрибути. Слід уникати їх використання, якщо це можливо.

incremental

Булів атрибут incremental – це розширення WebKit і Blink (тобто підтримується Safari, Opera, Chrome тощо), котрий, якщо присутній, каже користувацькому агентові обробляти поле як живий пошук. Поки користувач редагує значення поля, користувацький агент надсилає об'єктові HTMLInputElement, що представляє поле пошуку, події search. Це дає змогу оновлювати результати пошуку в коді в реальному часі, по ходу редагування пошуку користувачем.

Якщо incremental не заданий, то подія search надсилається лише тоді, коли користувач явно запускає пошук (наприклад, натиснувши клавішу Enter або Return при редагуванні поля).

Подія search обмежена в частоті, тож вона не надсилається частіше за визначений реалізацією інтервал.

results

Атрибут results, що підтримується лише Safari, це числове значення, що дає змогу перевизначити максимальну кількість записів, що виводиться в нативному спадному меню попередніх пошукових запитів елемента <input>.

Це значення повинно бути невід'ємним десятковим числом. Якщо його немає, або якщо задано недійсне значення, то використовується усталене максимальне число записів.

Застосування пошукових полів

Елементи <input> типу search – вельми подібні до полів типу text, окрім того, що вони створені конкретно для обробки пошукових запитів. По суті вони рівносильні у своїй поведінці, але користувацькі агенти можуть вирішити усталено оформлювати їх інакше (і, звісно, сайти можуть використовувати списки стилів, аби застосовувати до них власне оформлення).

Базовий приклад

<form>
  <div>
    <input type="search" id="mySearch" name="q" />
    <button>Шукати</button>
  </div>
</form>

Це візуалізується отак:

q – найпоширеніше значення атрибута name, що дається пошуковим полям, хоч це й не вимагається. При поданні пара ім'я-значення, що надсилається на сервер, має вигляд q=шукане.

[!NOTE] Не слід забувати задавати своїм полям name, бо інакше – нічого не буде надіслано.

Різниця між пошуковим та текстовим типами поля

Головна різниця полягає в способі, в який браузери такі поля обробляють. Перше, що слід зауважити: частина браузерів показує піктограму хрестика, котру можна клацнути, щоб мати змогу миттєво прибрати пошуковий запит; в Chrome ця дія також запускається натисканням Escape. Наступний знімок екрана – з Chrome:

Пошукове поле з фокусом, з рамкою фокуса, з текстом 'cats'. У полі біля правого боку є піктограма x.

На додачу до цього, сучасні браузери мають тенденцію до автоматичного збереження пошукових запитів, введених раніше на доменах, котрі з'являються як варіанти автодоповнення при наступному пошуку в пошукових полях на тому самому домені. Це допомагає користувачам, котрі мають тенденцію до пошуку за подібними чи тими самими запитами. Цей знімок екрана – з Firefox:

Поле в стані помилки, з червоною рамкою. Користувач ввів літеру 'h'. Спливний список вибору відкритий безпосередньо під полем, з двома варіантами – hello та hermansje.

Тепер погляньмо на кілька корисних метод, котрі можна застосувати до пошукових форм.

Задання заповнювачів

Всередині пошукового поля можна дати змістовний заповнювач, котрий служитиме підказкою щодо того, що робити з полем, за допомогою атрибута placeholder. Погляньте на наступний приклад:

<form>
  <div>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="Шукати на сайті…" />
    <button>Шукати</button>
  </div>
</form>

Візуалізація заповнювача – нижче

Підписи та доступність пошукових форм

Одна з проблем пошукових форм – їхня доступність. Загальноприйнята практика проєктування – не давати пошуковому полю підпису (хоч у нього може бути піктограма збільшувального скла чи щось подібне), адже призначення пошукового поля зазвичай доволі очевидне для зрячих користувачів, у зв'язку зі своїм розташуванням (цей приклад показує типовий патерн).

Проте це може призводити до спантеличення користувачів читачів з екрана, адже вони не отримують жодного словесного повідомлення про те, чим є пошукове поле. Один зі способів це обійти, не змінюючи візуальний дизайн, – використовувати можливості WAI-ARIA:

  • Атрибут role зі значенням search на елементі <form> змусить читачів з екрана оголошувати те, що ця форма є пошуковою.
  • Якщо цього не достатньо, то можна використати атрибут aria-label на самому <input>. Його значення повинно бути описовим текстовим підписом, котрий зачитають читачі з екрана; цей атрибут використовується як невізуальний еквівалент <label>.

Погляньмо на приклад:

<form role="search">
  <div>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="Шукати на сайті…"
      aria-label="Пошук у вмісті сайту" />
    <button>Шукати</button>
  </div>
</form>

Те, як це візуалізується, видно нижче:

Немає візуальної відмінності від попереднього прикладу, але користувачі читачів з екрана отримають набагато більше інформації.

[!NOTE] Дивіться більше інформації про такі можливості з доступності в Дороговказах та віхах.

Фізичний розмір елемента введення

Фізичний розмір поля введення можна контролювати за допомогою атрибута size. Так можна задавати число символів, котре водночас може показувати поле. У цьому прикладі, скажімо, пошукове поле – 30 символів завширшки:

<form>
  <div>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="Шукати на сайті…"
      size="30" />
    <button>Шукати</button>
  </div>
</form>

Результат – отаке ширше поле введення:

Валідація

Елементи <input> типу search мають такі ж можливості валідації, що й звичайні поля text. Не дуже ймовірно, що вам знадобиться використовувати можливості валідації до пошукових полів. У багатьох випадках користувачам доводиться просто дозволити шукати що завгодно, однак є кілька випадків, вартих осмислення, як то пошук даних відомого формату.

[!NOTE] Валідація форм HTML не є замінником серверних сценаріїв, котрі пересвідчуються, що введені дані мають відповідний формат. Кому завгодно занадто легко внести зміни в HTML, котрі дозволять обійти валідацію чи взагалі її усунути. Також можливо, що хтось обійде HTML взагалі й подасть дані напряму на сервер. Якщо серверний код не справляється з валідацією отриманих даних, може трапитись лихо, коли подаються невідповідно форматовані дані (або дані, що є завеликими, мають помилковий тип і так далі).

Примітка щодо оформлення

Для оформлення дійсних та недійсних елементів форми доступні корисні псевдокласи – :valid та :invalid. У цьому розділі використовується наступний CSS, котрий ставить позначку біля полів, що містять дійсні значення, і хрестик – біля полів, що містять недійсні.

input:invalid ~ span::after {
  content: "✖";
  padding-left: 5px;
  position: absolute;
}

input:valid ~ span::after {
  content: "✓";
  padding-left: 5px;
  position: absolute;
}

Ця техніка також вимагає, щоб після елемента форми стояв елемент <span>, котрий діє як тримач піктограм. Це знадобилося, бо частина типів полів у частині браузерів не надто коректно показує піктограми, поставлені після них.

Обов'язковість заповнення поля

Атрибут required можна використати як легкий спосіб зробити введення значення в поле обов'язковим перед дозволом на подання:

<form>
  <div>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="Шукати на сайті…"
      required />
    <button>Шукати</button>
    <span class="validity"></span>
  </div>
</form>

Це візуалізується так:

На додачу до цього, якщо спробувати подати форму, в яку не введено пошуковий запит, то браузер покаже повідомлення. Наступний приклад – з Firefox:

поле форми з повідомленням біля нього Please fill out this field

При спробах подати форму з різного роду недійсними даними в полях – будуть показані різні повідомлення; приклади – нижче.

Довжина значення поля

Мінімальну довжину в символах уведеного значення можна задати за допомогою атрибута minlength; подібно до цього – є maxlength для задання максимальної довжини.

Приклад нижче вимагає, щоб уведене значення було 4-8 символів завдовжки.

<form>
  <div>
    <label for="mySearch">Шукати користувача</label>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="Ідентифікатори користувачів бувають 4-8 символів завдовжки"
      required
      size="30"
      minlength="4"
      maxlength="8" />
    <button>Шукати</button>
    <span class="validity"></span>
  </div>
</form>

Це візуалізується так:

Якщо спробувати подати форму з менш ніж 4 символами, то буде показано відповідне повідомлення про помилку (котре відрізняється в різних браузерах). Якщо спробувати ввести понад 8 символів, то браузер не дасть цього зробити.

Задання патерну

Для задання регулярного виразу, котрому повинно відповідати введене значення, аби вважатися дійсним, можна використати атрибут pattern (дивіться експрес-курс у Валідуванні за регулярним виразом).

Погляньмо на приклад. Скажімо, що необхідно створити пошукову форму для ідентифікаторів продуктів, а всі ідентифікатори починаються з двох літер, після яких – чотири цифри. Наступний приклад таке покриває:

<form>
  <div>
    <label for="mySearch">Шукати продукт за ідентифікатором:</label>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="дві літери, після яких – чотири цифри"
      required
      size="30"
      pattern="[A-z]{2}[0-9]{4}" />
    <button>Шукати</button>
    <span class="validity"></span>
  </div>
</form>

Це візуалізується так:

Приклади

Добрий приклад використання пошукової форми в контексті можна побачити в нашому прикладі website-aria-roles (той же приклад в дії).

Технічний підсумок

Значення Рядок, що представляє значення, вміщене в пошуковому полі.
Події change та input
Доступні загальні атрибути autocomplete, list, maxlength, minlength, pattern, placeholder, required, size.
Атрибути IDL value
Інтерфейс DOM

HTMLInputElement

Методи select(), setRangeText(), setSelectionRange().
Неявна роль ARIA без атрибута list: searchbox з атрибутом list: combobox

Специфікації

Сумісність із браузерами

desktop mobile
Chrome Edge Firefox Internet Explorer Opera Safari WebView Android Chrome Android Firefox for Android Opera Android Safari on iOS Samsung Internet
type="search"
Chrome Full support 5
Edge Full support 12
Firefox Full support 4
Internet Explorer Full support 10
Opera Full support 10.6
Safari Full support 5
WebView Android Full support Так
Chrome Android Full support Так
Firefox for Android Full support Так
Opera Android Full support Так
Safari on iOS Full support Так
Samsung Internet Full support Так

Дивіться також