前言

看了网上一些关于网页进度条样式的资料,有很多方式实现,针对其展现形式,有用图片的,有用css2属性clip,有用flash的,本人就学会了一种,下面就简单来介绍一下。

css2的属性clip

如果你不是很明白clip属性,那么我就用大白话来解释一下,clip:rect(0px,0px,0px,0px)有四个值,同理是顺时针方向赋值,上右下左,记录改元素裁切方式,

例如:一个元素div,其width:300px;height:300px; clip:rect(0px,100px,60px,0px)

表示裁切的左边距离原元素上边缘0px;

裁切的右边距离原始左边缘100px;

裁切的下边距离原始元素上边缘是60px;

裁切的左边距离原始元素元素左边距离是0px;

如果明白了,那么再来一张图测试一下,如果设置是clip:rect(10px,100px,40px,5px)图片应该啥样子呢?如下

说到这里,我就当你明白了,继续往下说,

所以现在我们要改变的就是裁切元素的右值,让其等于制定的宽度,那么元素就全部呈现出来了。

设置进度条样式

对于css我做的还是比较low的,那么还是要贴出我很low的css代码,

  1. <style type="text/css">
  2. #progressBox{width:300px;height:60px;position:absolute;left:;border:1px solid #000;}
  3. #progressBar{background:blue;opacity:0.3;filter:alpha(opacity=30); width:300px;height:60px;position:absolute;clip:rect(0px,0px,60px,0px);left:;top:;}
  4. #progressText{color:Black;width:300px;height:60px;position:absolute;left:;top:;text-align:center; line-height:60px; font-family:Georgia;font-size:2em;font-weight:bold;}
  5. </style>

页面元素

  1. <body>
  2. <div id="progressBox">
  3. <div id="progressBar"></div>
  4. <div id="progressText">0%</div>
  5. </div>
  6. <input type="button" value="开 始" id="btn" style="position:absolute;left:50%;top:20%;"/>
  7. </body>

这里需要解释一下为啥会有3个元素,一个是元素容器(progressBox)基本就是想突出边框,让用户知道100%应该是有多长的容量,

第二个progressBar是表示不断变化的元素背景色设置为淡蓝色,

第三个是表示进度显示的数值文本

然后现在要做的就是js脚本

因为现在没有与服务器交互所以我就用setInterval来模拟增长因子

  1. timer = setInterval(progressFn, 10);
  2. function progressFn() {
  3. if (cent == max) {
  4. clearInterval(timer);
  5. } else {
  6. divbar.style.clip = "rect(0px," + cent + "px,60px,0px)";
  7. divText.innerHTML = Math.ceil((cent / max) * 100) + "%";
  8. cent++;
  9. }
  10. };

上边这段js是通过改变裁切的右边距实现展示进度条背景色,同时改变进度文本值。

XMLHttpRequest的progress事件实现前后交互的进度条显示

利用XMLHttpRequest第二版还定义的progress事件可以知道上传进度,来配合我们页面前端的展示进度来真正实现有后端交互的进度条

先上代码

  1. var xhr = new XMLHttpRequest();
  2. xhr.timeout = 8000;
  3. xhr.open('POST', form.action);
  4. xhr.send(formData);
  5. xhr.onreadystatechange = function () {
  6. if (xhr.readyState == 4 && xhr.status == 200) {
  7. console.log("xhr.responseText", xhr.responseText);
  8. } else {
  9. console.log("xhr.statusText", xhr.statusText);
  10. }
  11. };
  12. xhr.onprogress = updateProgress;
  13. //xhr.upload.onprogress = updateProgress;
  14. function updateProgress(event) {
  15. if (event.lengthComputable) {
  16. var percentComplete = event.loaded / event.total;
  17. console.log(event.loaded, event.total, 300 * percentComplete);
  18. progressFn(300 * percentComplete, max);
  19. }
  20. }
  21. xhr.ontimeout = function (event) {
  22. alert('请求超时!');
  23. }

其中的event.loaded表示当前加载了多少字节流,而event.total表示总共有多少字节流 得到这样一个百分比,

然后调用我们事先定义好的progressFn()函数就ok了,感觉还是挺方便的。

当然除了这种方式还有我前面提到过的配合flash来调用我们实现定义好的函数等。

下载地址  演示效果图

以上就是我今天想要分享的小知识点,本人水平有限,如果有错误和建议

还恳请指出,如果觉得对你有用,请支持一下。

用css2属性clip实现网页进度条的更多相关文章

  1. CSS3 圆形时钟式网页进度条

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. clip实现圆环进度条

    效果主要通过clip和transform:rotate实现 把圆环分为左右两个部分,通过角度旋转对图片剪切旋转角度<=180度的时候之旋转右边,当大于180度时右边固定旋转180度的同时旋转左边 ...

  3. Javascript 及 CSS3 实现进度条效果

    Javascript 及 CSS3 实现进度条效果 一:css2 属性clip实现网页进度条:  在实现之前,我们先来介绍一下clip属性,因为这个属性在css2.1中很少使用到,所以我们有必要来了解 ...

  4. HTML5多图片拖拽上传带进度条

    前言 昨天利用css2的clip属性实现了网页进度条觉得还不错,但是很多情况下,我们在那些时候用进度条呢,一般网页加载的时候如果有需要可以用,那么问题就来了,怎么才算整个加载完毕呢,是页面主要模块加载 ...

  5. 详解Bootstrap进度条组件

    在网页中,进度条的效果并不少见,如:平分系统.加载状态等,进度条组件使用了css3的transition和animation属性来完成一些特效,这些特效在IE9及IE9以下版本.Firefox的老版本 ...

  6. Android ProgressBar 反向进度条/进度条从右到左走

    近期的项目,有个需求须要使用条状图显示比例,而且右对齐,见下图: 我想到了使用进度条,这样不就不须要在代码动态绘制条状了,省了非常多活. 那么进度条如何从右向左显示呢? 方案一: 将ProgressB ...

  7. CSS制作环形进度条

    参考来源 <Radial progress indicator using CSS>,该文核心是用纯CSS来做一个环形的进度条.纯css的意思就是连百分比这种数字,都是css生成的.文章作 ...

  8. JS框架_(Progress.js)圆形动画进度条

    百度云盘 传送门 密码: 6mcf 圆形动画进度条效果: <!DOCTYPE html> <html lang="en"> <head> < ...

  9. cocos2d-x视频控件VideoPlayer的用户操作栏进度条去除(转载)

    目前遇到两个问题: (1)视频控件移除有问题,会报异常. (2)视频控件有用户操作栏,用户点击屏幕会停止视频播放. 对于第一个问题,主要是移除控件时冲突引起的,目前简单处理是做一个延时处理,先stop ...

随机推荐

  1. ABP-N层架构

    ABP理论学习之N层架构   返回总目录 自从写这个系列博客之后,发现很多园友还是希望有个直接运行的demo,其实在github上就有官方的demo,我直接把这demo的链接放到这里吧,另外,我分析, ...

  2. 【C语言探索之旅】 第一部分第十课:练习题+习作

    内容简介 1.课程大纲 2.第一部分第十课: 练习题+习作 3.第二部分第一课预告: 模块化编程 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C语言编写三 ...

  3. CF 444B(DZY Loves FFT-时间复杂度)

    B. DZY Loves FFT time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  4. therefore/so/hence/then/accordingly/Thus

    这几个词的区别大致可从以下几方面去看:1.therefore adv.因此, 所以=for that reason=consequently常用于连接两个并列分句,其前加“and”或分号“:”.He ...

  5. 有关Struts2a的ction直接使用response异步问题

    假设我们在项目中使用struts2,正在使用ajax而通信时后端程序.为简单起见,我们经常使用下面的方法:         ActionContext ac = ActionContext.getCo ...

  6. 泛泰A860(高通公司8064 cpu 1080p) 拂4.4中国民营recovery TWRP2.7.1.2文本(通过刷第三版)

    专业第三方开发团队 VegaDevTeam  (本team 由 syhost suky zhaochengw(z大) xuefy(大星星) tenfar(R大师) loogeo crazyi(天下无雪 ...

  7. jQuery EasyUI实现全部关闭tabs

    有时,当我们打开很多tabs当标签,要关闭一个接一个,它只能被关停 显然太麻烦,能够在选项卡的最右边加入一个button 实现关闭所有. 代码例如以下: <!DOCTYPE HTML PUBLI ...

  8. 采用 matlab 阅读SAR 元数据

    这方面能够參考书籍:"Digital processing of synthetic aperture radar data", by Ian Cumming and Frank ...

  9. nginx conf by linux kernel

    #nginx conf by linux kernel net.ipv4.tcp_max_tw_buckets = 6000 net.ipv4.ip_local_port_range = 1024 6 ...

  10. 数组名取地址所算数运算应注意的&quot;trap&quot;

    数组名取地址所算数运算应注意的"trap" 直接看代码: #include <stdio.h> int main() { int array[5]; printf(&q ...