2016-05-18 3 views
0

Я хочу создать входной диапазон, который имеет полосу дорожек в виде треугольника, как и многие входы объема. Вот пример.Как создать вход диапазона с пользовательской дорожкой формы без JS

enter image description here

Я прочитал это полезное руководство для стилизации входа, но он не имеет информации об изменении формы бара дорожки.

Я не хочу использовать пользовательский слайдер диапазона с JS, который изменяет реальный вход, я хочу использовать сам фактический диапазон ввода. Он также должен быть в основном перекрестным браузером.

Как это сделать?

ответ

1

Вы не можете надежно изменить форму самой дорожки в режиме кросс-браузера, но вы можете скрыть панель треков и поместить в нее элемент или изображение. Вот пример этого.

HTML

<input type="range" class="font-size-selector pd-select" id="font_size_selector" min="12" value="20" max="100" step="1"> 
<span class="triangle-range-background-slider"></span> 

CSS

/* Trangle */ 
.triangle-range-background-slider { 
    position: relative; 
    display: block; 
    margin-top: -27px; 
    height: 20px; 
    background: url('https://i.ytimg.com/vi/tntOCGkgt98/maxresdefault.jpg'); 
    background-size: 100% auto; 
    z-index: 1; 
} 

/* Input to work with triangle */ 
input[type=range] { 
    position: relative; 
    z-index: 3; 
} 

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

.triange-range-background-slider { 
    position: relative; 
    display: block; 
    margin-top: -27px; 
    border-top: 10px solid transparent; 
    border-right: 100px solid #3071a9; 
    border-bottom: 10px solid transparent; 
    z-index: 1; 
} 

Остальная часть CSS - это Hide and Thumb из ссылки CSS-Tricks, которую вы указали.

https://css-tricks.com/styling-cross-browser-compatible-range-inputs-css/

Скрыть ввода CSS

/* Hide */ 
    input[type=range] { 
    -webkit-appearance: none; /* Hides the slider so that custom slider can be made */ 
    width: 100%; /* Specific width is required for Firefox. */ 
    background: transparent; /* Otherwise white in Chrome */ 
    } 

    input[type=range]::-webkit-slider-thumb { 
    -webkit-appearance: none; 
    } 

    input[type=range]:focus { 
    outline: none; /* Removes the blue border. You should probably do some kind of focus styling for accessibility reasons though. */ 
    } 

    input[type=range]::-ms-track { 
    width: 100%; 
    cursor: pointer; 

    /* Hides the slider so custom styles can be added */ 
    background: transparent; 
    border-color: transparent; 
    color: transparent; 
    } 

Thumb Входной CSS

/* Thumb */ 
    /* Special styling for WebKit/Blink */ 
    input[type=range]::-webkit-slider-thumb { 
    -webkit-appearance: none; 
    border: 1px solid #000000; 
    height: 36px; 
    width: 16px; 
    border-radius: 3px; 
    background: #ffffff; 
    cursor: pointer; 
    // margin-top: -14px; /* You need to specify a margin in Chrome, but in Firefox and IE it is automatic */ 
    box-shadow: 1px 1px 1px #000000, 0px 0px 1px #0d0d0d; /* Add cool effects to your sliders! */ 
    } 

    /* All the same stuff for Firefox */ 
    input[type=range]::-moz-range-thumb { 
    box-shadow: 1px 1px 1px #000000, 0px 0px 1px #0d0d0d; 
    border: 1px solid #000000; 
    height: 36px; 
    width: 16px; 
    border-radius: 3px; 
    background: #ffffff; 
    cursor: pointer; 
    } 

    /* All the same stuff for IE */ 
    input[type=range]::-ms-thumb { 
    box-shadow: 1px 1px 1px #000000, 0px 0px 1px #0d0d0d; 
    border: 1px solid #000000; 
    height: 36px; 
    width: 16px; 
    border-radius: 3px; 
    background: #ffffff; 
    cursor: pointer; 
    } 
Смежные вопросы