滑块进度插件,条纯js实现(原创),可实例多个

所属分类:UI,输入,媒体-加载,拖和放,滑块和旋转

 21046  279  查看评论 (4)
分享到微信朋友圈
X
滑块进度插件,条纯js实现(原创),可实例多个 ie兼容10

更新时间:2019/6/5 上午9:55:40

更新说明:

1. 新增移动端适配,可自行通过移动端查看效果

2. 优化配置

drag: true, //默认开启拖拽,关闭设为false,不配置默认为true 
    tip: false, 关闭提示 可配置成对象
tip: {
    trigger: 'show', //一直显示;'hover':'hover':tip鼠标hover显示,默认为'show'         
    align: 'bottom' //显示位置,默认为'top',  可设置'top,bottom,left,right'    
}
tip显示为 % 进度, 获取数值不受影响

3.新增pro.onLoad(boolean),true:开启Loading动画,false:关闭Loading动画。


发布时间:2019-06-04 23:09:35

jq版本地址:

http://www.jq22.com/jquery-info21493

原生版相比jq版本更轻量,使用简单。

使用方法

引用css:

<link rel="stylesheet" href="css/progressJS.css" />

引用js: 

<script src="js/progressJS.js"></script>

html: 

<div class="progress"></div>

可自行设置progress的长宽,默认大小跟随屏幕可视区域而定,可自行覆盖进度条颜色尺寸等。

注意:如果改变了.ProgressLine .btn类,border大小和 transform的偏移量必须一致。

新增垂直样式.vertical{} transform也同理设置即可

.ProgressLine .btn{
    border: 6px solid #fff;
    transform: translate(6px, -50%);
}

js实例化:

var pro = new Progress('.progress')//传入需要实例的class id  和或任意可以被document.querySelector()识别的内容。

配置说明:

根据具体的需求来配置,除了getVal获取val值,你也可以不需要配置其它。

new Progress('.progress', {
    val: 10,
    size: 4,
    precision: 2,
    drag: 'on',
    direction: 'horizontal',
    tip: 'on',
    getVal: function(res) {
        console.log(res)
    }
})

详细说明:

val: 0 
//初始值 取值范围:0-100, 类型:number
size: 4 
//控件大小默认值为10,可结合css自行修改样式
precision: 2,
//val精度配置,默认保留0位小数,最多配位4位
drag: 'on',
//默认开启拖拽,关闭设为'off',不配置默认为'on'
direction: 'horizontal', 
//方向 默认水平 vertical 垂直
tip:'on'
//开启提示,默认为'off'关闭,也可以配一个对象
tip: {
         trigger: 'show', //显示方式:‘show’:一直显示,'hover':tip鼠标hover显示,默认为'show'
         align: 'bottom'//显示位置,默认为'top',  可设置'top,bottom,left,right'
        }
getVal: function(res){
 console.log(res)
}
//获取val回调方法

如果是视频进度条则需要动态更新val,我们也提供了这样的方法

var pro = new Progress()
pro.updateVal(val)

也可以通过 pro.updateVal(val) 重置初始值

//模拟音视频时间轴更新
var i = 0, timeID
timeID = setInterval(function() {
    i += 0.1
    pro.updateVal(i)
    console.log(pro.val)
    if (i >= 100) {
        clearInterval(timeID)
    }
}, 15)

以上就是目前插件的配置,其它功能将会陆续更新中。

TIP:本插件源码是面向对象实现的,非常适合一些小白学习哦

如有疑问,可咨询作者Q:1194891819

相关插件-加载,拖和放,滑块和旋转

progress 标签制作加载(原创)

利用HTNL5新标签制作进度条加载,代码非常简单且实用。
  加载
 14295  214

带刻度的进度条

html5 CSS3渐变进度条动画效果
  加载
 33743  312

jQuery 圆型进度条

jQuery canva圆型进度条,可通参数快速修改进度条
  加载
 36018  339

jQuery局部加载

一个页面有多个接口请求时,接口返回的速度不一样,可以将所有接口返回后分开渲染,先返回的先渲染
  加载
 23127  307

讨论这个项目(4)回答他人问题或分享插件使用方法奖励jQ币 评论用户自律公约

    goodstudy 0
    2021/1/19 14:53:05
    当页面出现滚动条后,垂直滑动条点击就不准确呀 回复
    冬日 0
    2019/11/15 16:22:44
    点击也是可以触发滑块的 怎么关闭这个 回复
    Queen_木土 0
    2019/9/18 16:57:47
    请问在哪里修改最大值和最小值
        冬日0
        2019/11/15 16:25:05
        最大值可以把里面的js 100全部修改成200
    回复
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
取消回复