html5 progress数值不完整,HTML5progress进度条详解

5268f80b9b1e01f982625ef6fac83ca1.png

HTML5 progress进度条详解

HTML5 progress 元素简介

progress是HTML5的一个新元素,表示定义一个进度条,用途很广泛,可以用在文件上传的进度显示,文件下载的进度显示,也可以作为一种loading的加载状态条使用。

html5 progress进度条语法

点击这里查看html5 progress进度条的样子。

html5 progress 属性

progress max

max属性表示进度条的进度最大值,如果有此值,必须是大于0的有效浮点数。max的默认值是1.

progress value

value属性表示进度条完成的进度之,value值的范围为0~max之间。如果没有设置max属性,那么value属性值的范围要在0~1之间。

如果没有value值,那么完成进度是不确定的。这时候表示任务正在进行中,但不知道多长时间可以完成。这时候的progress在webkit浏览器中我们可以用作loading来使用,表示正在页面加载中,或者ajax请求后台数据中。

ef8735a5df164f574fa35e46620d1619.png

上图截自chrome浏览器。

没有设置value值的progress就像一个加载中loading,中间的进度块来回游荡。

没有value的progress在window7下的模样如下图:

3be41846a15e600724f4858981eec227.png

确实有点丑,不过是继承了windows的典型风格。

html5 progress兼容性

progress在IE10+浏览器都支持

71e3d1e47fe2ac150f0e3d0d03b0d41a.png

html5 progress 进度效果展示

progress动画效果模拟代码如下:

您的浏览器不支持progress元素

function goprogress(){

var pro=document.getElementsByTagName("progress")[0];

gotoend(pro,0);

}

function gotoend(pro,value){

var value=value+1;

pro.value=value;

if(value<100) {

setTimeout(function(){gotoend(pro, value);},20)

}else{

setTimeout(function(){alert("任务完成")},20);

}

}

点击这里查看progress动画模拟。

html5 progress相关样式设置

我们以实现一个progress的自定义样式为例子,来讲述progress有哪些样式可以供我们设置。

7c2a00c1f47cb83bd098014e67d72ea5.png

我们要把progress改变成上面这种模样。

代码如下:

您的浏览器不支持progress元素

.mypro{

background:orange;

border:1px solid red;

border:2px solid #000;

width:300px;

height:50px;

-webkit-appearance: none;

}

::-ms-fill{

background:deeppink;

}

::-moz-progress-bar{

background:deeppink;

}

::-webkit-progress-bar{

background:orange;

}

::-webkit-progress-value{

background:deeppink;

}

progress可以设置width,height,border等常用属性。

对于IE10+,firefox浏览器,可以用background设置进度条的背景色。

对于webkit浏览器,使用::-webkit-progress-bar设置进度条的背景色。

对于IE10+,用::-ms-fill设置进度条完成进度的背景色。

对于firefox,用::-moz-progress-bar设置进度条完成进度的背景色。

对于webkit浏览器,使用::-webkit-progress-value设置进度条完成进度的背景色。

注意:::-webkit-progress-bar设置的是进度条的背景色,而::-moz-progres-bar设置的是进度条完成进度的背景色,正好是反着的。

而且对于webkit浏览器,在IOS上要用-wekbit-appearance:none来清空progress的默认样式,才能让背景色,进度颜色起作用。

点击这里,查看自定义progress进度条样式。

html5 progress结语

我们可以在ajax2上传文件中,upload.onprogress事件回调中使用progress可以很方便的显示文件上传的进度。也可以在FileReader预览图片中使用的onprogress事件中使用progress元素显示图片读取的进度。

本文讲解了HTML5 progress进度条,更多相关内容请关注Gxl网。

相关推荐:

简易 PHP+MySQL 分页类

两个不用递归的树形数组构造函数

HTML转Excel,并实现打印,下载功能

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值