Как сделать - пользовательские ползунки
Узнайте, как создавать пользовательские ползунки диапазона с помощью CSS и JavaScript.
Default:
Square:
Round:
Image:
Value:Создание ползунка диапазона
Шаг 1) добавить HTML:
Пример
<div class="slidecontainer">
<input type="range" min="1" max="100"
value="50" class="slider" id="myRange">
</div>
Шаг 2) добавить CSS:
Пример
.slidecontainer {
width: 100%; /* Width of the outside
container */
}
/* The slider itself */
.slider
{
-webkit-appearance: none; /* Override default
CSS styles */
appearance: none;
width:
100%; /* Full-width */
height: 25px; /* Specified height
*/
background: #d3d3d3; /* Grey background */
outline:
none; /* Remove outline */
opacity: 0.7; /* Set
transparency (for mouse-over effects on hover) */
-webkit-transition:
.2s; /* 0.2 seconds transition on hover */
transition: opacity .2s;
}
/* Mouse-over
effects */
.slider:hover
{
opacity: 1; /* Fully shown on mouse-over */
}
/* The slider handle (use -webkit- (Chrome, Opera, Safari,
Edge) and -moz- (Firefox) to override default look) */
.slider::-webkit-slider-thumb {
-webkit-appearance: none; /* Override default look */
appearance: none;
width: 25px; /* Set a specific slider handle width */
height: 25px;
/* Slider handle height */
background: #4CAF50; /* Green
background */
cursor: pointer; /* Cursor on hover */
}
.slider::-moz-range-thumb
{
width: 25px; /* Set a specific slider handle width */
height: 25px;
/* Slider handle height */
background: #4CAF50; /* Green background */
cursor: pointer;
/* Cursor on hover */
}
Шаг 3) добавить JavaScript:
Создайте ползунок динамического диапазона для отображения текущего значения с помощью JavaScript:
Пример
var slider = document.getElementById("myRange");
var output =
document.getElementById("demo");
output.innerHTML = slider.value;
// Display the default slider value
// Update the current slider
value (each time you drag the slider handle)
slider.oninput = function() {
output.innerHTML =
this.value;
}
Круглый ползунок
Для создания круглого маркера ползунка используйте border-radius
свойство. Совет:
Установите высоту ползунка на другое значение, чем ползунок, если вы хотите неравные высоты (15пкс vs. 25пкс в этом примере):
Пример
.slider
{
-webkit-appearance: none;
width:
100%;
height: 15px;
border-radius: 5px;
background: #d3d3d3;
outline:
none;
opacity: 0.7;
-webkit-transition:
.2s;
transition: opacity .2s;
}
.slider::-webkit-slider-thumb {
-webkit-appearance: none;
appearance: none;
width: 25px;
height: 25px;
border-radius: 50%;
background: #4CAF50;
cursor: pointer;
}
.slider::-moz-range-thumb
{
width: 25px;
height: 25px;
border-radius: 50%;
background: #4CAF50;
cursor: pointer;
}
Иконка слайдер/изображение
Чтобы создать значок или изображение маркера ползунка, используйте background
свойство и вставьте URL-адрес изображения:
Пример
.slider::-webkit-slider-thumb {
-webkit-appearance: none;
appearance: none;
width: 23px;
height: 24px;
border:
0;
background: url('contrasticon.png');
cursor: pointer;
}
.slider::-moz-range-thumb
{
width: 23px;
height: 25px;
border: 0;
background: url('contrasticon.png');
cursor: pointer;
}