• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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">

    (详情参考https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range)

    默认样式:

     <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">的轨道

    详情参考:https://developer.mozilla.org/en-US/docs/Web/CSS/::-webkit-slider-runnable-track

      input[type=range]::-webkit-slider-thumb {
       -webkit-appearance: none; /* 去除滑块的默认样式 */
       height: px;
       width: px;
       margin-top: -px;
       background:#BE;
       border-radius: %;
       border: solid .em rgba(, , , .);
       box-shadow:  .em .em #b;
     }

    ::-webkit-slider-thumb 可以获取<input type="range">的轨道

    总结

    以上所述是小编给大家介绍的HTML5实现自带进度条和滑块滑杆效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    上一篇:使用HTML5 Geolocation实现一个距离追踪器
    下一篇:详解Html5 监听拦截Android返回键方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    HTML5实现自带进度条和滑块滑杆效果 HTML5,实现,自带,进度,条,