Вертикальное отображение slider-а в HTML5: решение проблемы

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

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

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

Превратить горизонтальный элемент ввода с типом range в вертикальный просто – нужна CSS-трансформация. Ниже представлен пример кода, который ориентирует ползунок вверх:

HTML
Скопировать код
<input type="range" class="vertical-slider">
CSS
Скопировать код
.vertical-slider {
  width: 25px; /* Ширина ползунка */
  height: 150px; /* Высота обеспечивает вертикальное расположение */
  transform: rotate(-90deg); /* Поворачиваем на 90 градусов для вертикали */
  transform-origin: 75px 75px; /* Центр вращения */
}

.vertical-slider::-webkit-slider-thumb {
  /* Стилизация ползунка – поле для творчества */
  background: #4CAF50; 
}

.vertical-slider::-moz-range-thumb {
  /* Стилие для ползунка в Firefox */
  background: #4CAF50;
}

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

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

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

Немного переосмыслите ситуацию: если обычно горизонтальный ползунок перемещается влево-вправо, то в нашем случае он движется по вертикали, подобно тому, как ракета взлетает в космос:

Markdown
Скопировать код
Горизонтальный Ползунок: ⬅️───➡️
Вертикальный Ползунок:   ⬆️
                         🏔
                         🚁
                         🚀

Особенности браузеров: уникальные свойства и капризы

Firefox обладает особенностями, которые следует учитывать. Для адаптации ползунка под этот браузер добавьте атрибут orient со значением vertical:

HTML
Скопировать код
<input type="range" class="vertical-slider" orient="vertical">

Что касается Internet Explorer, то иногда здесь необходимо делать компромиссы. Для этого браузера используйте свойство writing-mode:

CSS
Скопировать код
.vertical-slider {
  writing-mode: bt-lr; /* Код под IE */
}

Совместимость с разными браузерами: всё об универсальности

Проверьте, работает ли ползунок корректно в различных браузерах. Для этого используйте специфичные для браузеров префиксы -webkit-, -moz-, -ms-, и -o-:

CSS
Скопировать код
.vertical-slider {
  -webkit-transform: rotate(-90deg);
  -moz-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  -o-transform: rotate(-90deg);
  transform: rotate(-90deg);
}

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

Доступность: потому что каждый пользователь важен

Уделите внимание доступности и удобству использования. Простые и понятные пользовательские интерфейсы должны соответствовать стандартам доступности (a11y) и иметь корректные атрибуты aria.

Продвинутые настройки: для тех, кто хочет большего

Кастомизируйте вертикальный ползунок с помощью дополнительных параметров следующим образом:

Оптимальные интервалы и начальные точки

Вы можете настроить диапазон и выбранное значение ползунка через атрибуты min, max, step, и value:

HTML
Скопировать код
<input type="range" min="0" max="100" step="1" value="50" class="vertical-slider">
Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Власти стиля

Погрузитесь в мир CSS, чтобы стилизовать ползунок. Добавьте, к примеру, скругление углов, используя класс .round:

CSS
Скопировать код
.vertical-slider.round {
  border-radius: 10px; /* Нежный штрих в дизайне */
}

От стилизации до мастерства

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

Сделайте одолжение будущему себе: пишите код вечно

Напишите код так, чтобы будущий вам был благодарен. Документируйте CSS для удобства поддержки и следите за новинками, используя такие ресурсы, как MDN и CSS-Tricks.

Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Что нужно добавить в атрибуты для корректного отображения вертикального ползунка в Firefox?
1 / 5