HTML select с вводом собственного значения: решение

Пройдите тест, узнайте какой профессии подходите

Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

Данную функциональность можно реализовать с помощью элемента select, в котором предусмотрен вариант "Другое", и элемента input. Последний активируется при выборе указаного варианта. Синхронизацию этих элементов можно обеспечить при помощи JavaScript.

HTML
Скопировать код
<select id="selectBox" onchange="document.getElementById('textInput').style.display = this.value === 'other' ? 'block' : 'none';">
  <option value="option1">Вариант 1</option>
  <option value="option2">Вариант 2</option>
  <option value="other">Другое...</option>
</select>
<input type="text" id="textInput" style="display:none;" placeholder="Введите своё значение"/>

Такой подход позволяет гибко управлять отображением поля input, давая пользователю возможность выбирать из предложенного списка или же вводить свои значения.

Кинга Идем в IT: пошаговый план для смены профессии

Интеграция комбобокса на HTML5

Комбобокс на HTML5 расширяет возможности стилизации и функциональности форм. Это набор из элементов input и datalist, который предоставляет опции выбора из предустановленного списка или ввода собственного значения.

HTML
Скопировать код
<!-- Вот что вам нужно — комбобокс на HTML5! 😎 -->
<input list="options" id="comboInput" placeholder="Выберите из списка или введите своё значение...">
<datalist id="options">
  <option value="Вариант 1"></option>
  <option value="Вариант 2"></option>
</datalist>

Использование элемента datalist позволит сохранить функциональность выпадающего списка, добавив к ней возможность ввода собственного значения, подобно тому, как можно вводить код для разблокировки уровня в игре.

Не забудьте проверить совместимость выбранного решения с различными браузерами на сайте caniuse и убедиться в его корректности работы.

Визуализация

Вообразите буфет, где представлены разные блюда:

1️⃣ Суши (🍣) 2️⃣ Пицца (🍕) 3️⃣ Салат (🥗)

Либо вы можете принести что-то своё (🗒️):

4️⃣ [ Введите название вашего любимого блюда здесь! ]

Этот пример наглядно иллюстрирует основную концепцию HTML-формы с выбором и включением собственного значения.

Изучение возможностей комбобокса на HTML5

Чтобы обеспечить корректную работу комбобокса, изучите связь между input и datalist — их идентификаторы и атрибуты должны совпадать.

Вот краткое сравнение преимуществ и недостатков:

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

В таблице ниже приведено сравнение двух альтернатив:

Markdown
Скопировать код
| Подход             | Преимущества                            | Недостатки                             |
|--------------------|----------------------------------|------------------------------------|
| Традиционный Select| Знакомый интерфейс; Доступность | Ограниченность предустановленными вариантами выбора |
| Комбобокс на HTML5 | Возможность редактирования введённых данных; Современный опыт пользовательского взаимодействия | Разные степени поддержки браузерами |

Улучшение пользовательского опыта с помощью альтернатив

Использование внешних библиотек

Для решения более сложных задач подойдут внешние библиотеки, например, такие как Select2 или Chosen, которые расширяют возможности электронной формы выбора.

Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Разработка на JavaScript

Собственный интерактивный компонент — отличная альтернатива. Ваш выпадающий список на JavaScript, составленный из списка опций и поля ввода, может значительно улучшить интерфейс.

JS
Скопировать код
// Псевдокод для создания собственного выпадающего списка
class CustomDropDown {
  constructor(options) {/* Шаблон для подачи */}
  render() {/* Визуализация готова */}
  handleSelection() {/* Обработка выбора */}
  allowCustomValue() {/* Добавление пользовательского значения */}
}

Другие замечания

Доступность для всех

При разработке не забывайте о важности доступности. Управлять формой должно быть удобно с помощью клавиатуры, она должна быть доступна для скринридеров. В этом вам помогут соответствующие роли и атрибуты ARIA.

Поддержание валидации формы

Когда пользователь вводит свои значения, важно проверять их на валидность. Для предотвращения отправки некорректных данных применяйте HTML5 API для валидации ограничений.

Полезные материалы

  1. <select>: элемент выбора – HTML: HyperText Markup Language | MDN — Обзор элемента <select>.
  2. Начало работы | Select2 – jQuery библиотека для выбора элементов — Ознакомьтесь с возможностями Select2, меняющими интерактивность элементов выбора.
  3. Chosen: jQuery плагин от Harvest для повышения удобства работы с выборамиChosen трансформирует привычные select-элементы в удобные для взаимодействия боксы.
  4. Пример использования Listbox | APG | WAI | W3C — Указания по созданию доступных выпадающих списков с применением атрибутов ARIA.
  5. HTML-стандарт — Рекомендации по валидации форм и API ограничений в HTML5.
  6. Как создать настраиваемый элемент выбора — Руководство по созданию настраиваемых select-боксов с помощью CSS и JavaScript.
Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Какой элемент HTML можно использовать для выбора собственного значения пользователем?
1 / 5