这是一款jQuery和CSS3斑马线样式range滑块特效。该range滑块通过css3将普通的range滑块渲染成斑马线样式,并通过jquery代码来控制滑块数值的显示。
在页面中引入jquery和bootstrap.css文件。
<link rel="stylesheet" href="css/bootstrapcss"> <script type="text/javascript" src="js/jquery.js"></script>
该range滑块的基本HTML结构如下:
<div class="container"> <div class="row pad-15"> <div class="col-md-offset-2 col-md-8"> <div class="range-slider"> <input type="range" value="150" min="0" max="500"> <span class="range-value">0</span> </div> <div class="range-slider"> <input type="range" value="280" min="0" max="500"> <span class="range-value">0</span> </div> <div class="range-slider"> <input type="range" value="360" min="0" max="500"> <span class="range-value">0</span> </div> </div> </div> </div>
然后通过下面的CSS样式来对滑块进行美化,将它渲染为斑马线样式。
.range-slider{ margin: 50px 0 0 0; } .range-slider input[type="range"]{ width: calc(100% - (68px)); height: 12px; background: #f8fc04; background-image: repeating-linear-gradient(28deg, transparent, transparent 10px, #08b2e3 10px, #08b2e3 20px); box-shadow: inset 0 2px 5px rgba(0, 0, 0, 0.4); outline: none; float: left; -webkit-appearance: none; position: relative } .range-slider input[type="range"]::-webkit-slider-thumb{ width: 35px; height: 35px; background: #2c2144; border-left: 5px solid #08b2e3; border-right: 5px solid #08b2e3; cursor: pointer; -webkit-appearance: none; appearance: none; transition: all 0.15s ease 0s; } .range-slider input[type="range"]::-webkit-slider-thumb:hover, .range-slider input[type="range"]:active::-webkit-slider-thumb{ background: #08b2e3; } .range-slider input[type="range"]::-moz-range-thumb{ width: 25px; height: 35px; background: #2c2144; border-radius: 0; border: none; border-left: 5px solid #08b2e3; border-right: 5px solid #08b2e3; cursor: pointer; transition: all 0.15s ease 0s; } .range-slider input[type="range"]::-moz-range-thumb:hover, .range-slider input[type="range"]:active::-moz-range-thumb{ background: #08b2e3; } .range-slider .range-value{ display: inline-block; width: 50px; height: 50px; line-height: 50px; background: #fff; margin-left: 8px; font-size: 15px; font-weight: 600; color: #000; text-align: center; position: relative; top: -20px; -webkit-clip-path: polygon(40% 0%, 40% 20%, 100% 20%, 100% 80%, 40% 80%, 40% 100%, 0% 50%); clip-path: polygon(40% 0%, 40% 20%, 100% 20%, 100% 80%, 40% 80%, 40% 100%, 0% 50%); } ::-moz-range-track{ background: transparent; border: 0; }
最后通过下面的jquery代码,来在拖动滑块时,动态显示滑块的数值。
$(document).ready(function(){ var rangeSlider = function(){ var slider = $('.range-slider'), range = $('.range-slider input[type="range"]'), value = $('.range-value'); slider.each(function(){ value.each(function(){ var value = $(this).prev().attr('value'); $(this).html(value); }); range.on('input', function(){ $(this).next(value).html(this.value); }); }); }; rangeSlider(); });