HTML5实现自带进度条和滑块滑杆效果
一、H5自带进度条
<div id="d"> <p id="pgv">进度%</p> <progress id="pg" max="" value=""></progress> </div>
运用progress标签,设置好min和max数值就好。可以用value获取其中的进度值
function staticProgress () { var pg = document.getElementById('pg') var pgv = document.getElementById('pgv') var timer = setInterval(function () { if (pg.value !== ) { pg.value++ pgv.innerHTML = '进度' + pg.value + '%' } else { pgv.innerHTML = '加载完成' clearInterval(timer) } }, ) }
最终效果如下
这个显示效果是chrome浏览器的,IE和FireFox的是的样式!
样式更改
progress{ -webkit-appearance: none; } ::-webkit-progress-bar{ / 获取progress / background-color: orange; / 进度条未被填充的背景颜色 / } ::-webkit-progress-value { background-color: rgb(, , ); / 进度条被填充部分的背景颜色 / } ::-webkit-progress-inner-element { border: px solid black; / 进度条的内边框,注意跟outline区分 / }
这里的样式全部是针对webkit内核的,其他的不支持~~~ 效果如下
二、H5自带滑块
将input的type设置为range。这个属性不是所有浏览器都支持,如果不支持,会返回默认属性,就是<input type="text">
(详情参考)
默认样式
<div id="d"> <p>H可拖动滑块:</p> <input type="range" name="points" min="" max="" id="hpro"/> </div>
1、自带属性
(1)、defaultValue = (rangeElem.max < rangeElem.min) ? rangeElem.min : rangeElem.min + (rangeElem.max - rangeElem.min)/2;
默认值 = (设置最大值 < 设置最小值)?设置最小值 : 设置最小值 + ( 设置最大值 - 设置最小值 ) / 2 ———————— 其实就是取中间值
我们可以用value="7"设置滑块的值。
(2)、<input type="range" min="-10" max="10">
min: 设置最小值; max: 设置最大值
(3)、<input type="range" min="5" max="10" step="0.01">
step: 设置步进值,默认是1。如果min或者max设置了小数点,比如max="3.14",这个小数点就取不到了,那么可以将step设置为: step="any"。
(4)、hash marks和label
注意目前没有哪个浏览器完全支持hash marks和label这两个属性,比如Firefox两个都不支持,Chrome支持hash marks不支持label.
a) hash marks
<input type="range" name="points" min="" max="" step="any" id="hpro" list="tickmarks"/> <datalist id="tickmarks"> <option value=""> <option value=""> <option value=""> <option value=""> <option value=""> <option value=""> <option value=""> <option value=""> <option value=""> <option value=""> <option value=""> </datalist>
b) label
<input type="range" name="points" min="" max="" step="any" id="hpro" list="tickmarks"/> <datalist id="tickmarks"> <option value="" label="%"> <option value=""> <option value=""> <option value=""> <option value=""> <option value="" label="%"> <option value=""> <option value=""> <option value=""> <option value=""> <option value="" label="%"> </datalist>
(5)、autofocus可以设置或返回滑块是否自动获得焦点,设置为true后,进入网页会自动锁定滑块,在键盘上按上下左右都可以控制
2、外观美化
input[type=range] { outline: none; -webkit-appearance: none; / 去除系统默认appearance的样式,常用于IOS下移除原生样式 / border-radius: px; }
-webkit-appearance: none; 去除默认样式
input[type=range]::-webkit-slider-runnable-track { height: px; border-radius: px; box-shadow: px px #deff, inset .em .em #d; }
::-webkit-slider-runnable-track 是个CSS伪类元素,不是所有浏览器都支持。可以获取<input type="range">
的轨道
详情参考
input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; / 去除滑块的默认样式 / height: px; width: px; margin-: -px; background:#BE; border-radius: %; border: solid .em rgba(, , , .); box-shadow: .em .em #b; }
::-webkit-slider-thumb 可以获取<input type="range">
的轨道
以上所述是长沙网络推广给大家介绍的HTML5实现自带进度条和滑块滑杆效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML