Кратко
СкопированоС атрибутом multiple можно выбрать несколько имейлов или файлов в <input>, либо несколько вариантов в списке <select>.
Пример
СкопированоВ списке ниже есть лишние слова. Их можно выбрать, зажав клавишу Ctrl для Windows или ⌘ на macOS. Ещё можно пользоваться Shift, но тогда выбор получится областью: от первого кликнутого слова до второго, что не очень подходит для примера.
<select size="5" multiple> <option>Красный</option> <option>Классный</option> <option>Зелёный</option> <option>Синий</option> <option>Съел иней</option></select>
<select size="5" multiple>
<option>Красный</option>
<option>Классный</option>
<option>Зелёный</option>
<option>Синий</option>
<option>Съел иней</option>
</select>
Как пишется
СкопированоАтрибут multiple можно указать без значения, он доступен для тега <input> с type или type, а также для тега <select>.
Создадим <input> с возможностью указать несколько имейлов через запятую. Для этого просто добавим к нему атрибут multiple.
Теперь, если кликнуть по полю ввода, <input> любезно предложит имейлы. Но когда мы что-то выберем, например «бригадира», список схлопнется.
Это нормально, потому что <input> нам уже подсказал имейл, а мы этим воспользовались, так что он ретировался и больше не помогает. Чтобы снова вызвать список для второго имейла, нужно добавить запятую после первого адреса внутри поля ввода — и так далее. Не работает в Safari 😔
<input type="email" list="list-of-emails" multiple><datalist id="list-of-emails"> <option value="nekto@doka.guide">Неизвестный</option> <option value="prikolist333@doka.guide">Друг шутник</option> <option value="anderyBoss@doka.guide">Босс Андрей</option> <option value="grish111a@doka.guide">Просто Гриша</option> <option value="brigadir@doka.guide">Бригадир</option> <option value="s0123tr1012dgs@doka.guide">Не знаю кто</option> <option value="printerDanila01@doka.guide">Почта для принтера</option></datalist>
<input type="email" list="list-of-emails" multiple>
<datalist id="list-of-emails">
<option value="nekto@doka.guide">Неизвестный</option>
<option value="prikolist333@doka.guide">Друг шутник</option>
<option value="anderyBoss@doka.guide">Босс Андрей</option>
<option value="grish111a@doka.guide">Просто Гриша</option>
<option value="brigadir@doka.guide">Бригадир</option>
<option value="s0123tr1012dgs@doka.guide">Не знаю кто</option>
<option value="printerDanila01@doka.guide">Почта для принтера</option>
</datalist>
Создадим <input> с атрибутом multiple, но теперь для возможности закачать несколько файлов.
<input type="file" multiple>
<input type="file" multiple>
Доступность
СкопированоВ ARIA есть атрибут aria. Он тоже нужен для выбора нескольких опций или файлов.
Старайтесь всегда использовать multiple. aria поможет в сложных ситуациях, когда создаёте кастомные элементы.