基于jQuery实现模拟页面加载进度条


Posted in Javascript onApril 01, 2013

因为我们无法通过任何方法获取整个页面的大小和当前加载了多少,所以想制作一个加载进度条的唯一办法就是模拟。那要怎么模拟呢?
基于jQuery实现模拟页面加载进度条

我们知道,页面是从上往下执行的,也就是说我们可以大致估算出在页面的某个位置加载了多少,而后用jq模拟出一个进度条来显示。

首先我们先画一个进度条的样子,也就是上图图中的样子,这个不用过多说明,自己看代码
CSS

.loading{position:relative;top:0;left:0} 
.tip1{float:left;background:#A70000;color:#fff;height:32px;line-height:32px;padding:0 15px;border:0;position:relative} 
.jindu{float:left;margin-left:20px;color:#fff;width:150px;height:32px;line-height:32px;background:#000;position:relative} 
.jindu b{color:#A70000;width:0;height:0;font-size:0px;border-width:10px;border-color:#fff #fff #fff #A70000;border-style:solid;position:absolute;left:-20px;top:5px;overflow:hidden} 
.jindu .jindu2{width:0px;height:32px;line-height:32px;background:#A70000;position:absolute} 
.jindu .text{width:150px;height:32px;line-height:32px;text-align:center;position:absolute} 
 

HTML
<div class="loading"> 
<div class="tip1">系统初始化中</div> 
<div class="jindu"> 
<b></b> 
<div class="jindu2"></div> 
<div class="text">页面总进度 <font>0</font>%</div> 
</div> 
</div>

这时候注意了,我们要引用jquery库,引用的位置不是在head区域,而是紧接着html代码下面写。为什么要这样,因为样式我们放head里的原因是保证页面加载第一步就把样式加载好,这样页面不会乱。而JS则不需要,再加上页面上大的文件主要也就是js,所以放在body里加载js是为了进度条考虑。
进度条画好了,jquery引用了,我们现在要写个方法,也就是可以让进度条动起来
var loading = function(a,b){ 
var c = b*1.5; 
if(b==100){ 
$('.bgloader .jindu2').animate({width:c+'px'},500,function(){ 
$('.bgloader .tip1').text(a); 
$('.bgloader font').text(b); 
$('.bgloader .loading').animate({top:'-32px'},1000,function(){ 
$('.bgloader').fadeOut(); 
}); 
}); 
}else{ 
$('.bgloader .jindu2').animate({width:c+'px'},500,function(){ 
$('.bgloader .tip1').text(a); 
$('.bgloader font').text(b); 
}); 
} 
};

这里我写了个loading(a,b),两个参数分别是显示加载内容提示信息和加载进度百分比,然后,我用了其他几个js库做加载进度测试
<script type="text/javascript">loading('正在加载jQuery UI',30);</script> 
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.16/jquery-ui.min.js"></script> 
<script type="text/javascript">loading('正在加载Chrome Frame',50);</script> 
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/chrome-frame/1.0.2/CFInstall.min.js"></script> 
<script type="text/javascript">loading('正在加载EXTJS',70);</script> 
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/ext-core/3.1.0/ext-core.js"></script> 
<script type="text/javascript">loading('正在加载mootools',90);</script> 
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/mootools/1.4.1/mootools-yui-compressed.js"></script> 
<script type="text/javascript">loading('正在加载dojo',100);</script> 
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/dojo/1.6.1/dojo/dojo.xd.js"></script>

demo下载地址:点击下载
Javascript 相关文章推荐
JavaScript 对象、函数和继承
Jul 07 Javascript
javascript 必知必会之closure
Sep 21 Javascript
对象无length属性时IE6/IE7中无法将其转换成伪数组(ArrayLike)
Jul 31 Javascript
使用js判断数组中是否包含某一元素(类似于php中的in_array())
Dec 12 Javascript
Js获取下拉框选定项的值和文本的实现代码
Feb 26 Javascript
让table变成exls的示例代码
Mar 24 Javascript
javascript 获取HTML DOM父、子、临近节点
Jun 16 Javascript
jQuery实现监控页面所有ajax请求的方法
Dec 10 Javascript
Ionic实现页面下拉刷新(ion-refresher)功能代码
Jun 03 Javascript
利用Node.js对文件进行重命名
Mar 12 Javascript
Vue 中使用vue2-highcharts实现top功能的示例
Mar 05 Javascript
基于Angularjs-router动态改变Title值的问题
Aug 30 Javascript
javascript ie6兼容position:fixed实现思路
Apr 01 #Javascript
JavaScript中的onerror事件概述及使用
Apr 01 #Javascript
js捕获鼠标右键菜单中的粘帖事件实现代码
Apr 01 #Javascript
向当前style sheet中插入一个新的style实现方法
Apr 01 #Javascript
select标签模拟/美化方法采用JS外挂式插件
Apr 01 #Javascript
html组件不可输入(只读)同时任何组件都有效
Apr 01 #Javascript
jQuery 网易相册鼠标移动显示隐藏效果实现代码
Mar 31 #Javascript
You might like
PHP 杂谈《重构-改善既有代码的设计》之一 重新组织你的函数
2012/04/09 PHP
JavaScript 变量命名规则
2009/09/23 Javascript
jQuery.extend 函数详解
2012/02/03 Javascript
服务器端的JavaScript脚本 Node.js 使用入门
2012/03/07 Javascript
NodeJs基本语法和类型
2015/02/13 NodeJs
详解JavaScript中void语句的使用
2015/06/04 Javascript
JavaScript中getUTCMinutes()方法的使用详解
2015/06/10 Javascript
javascript中tostring()和valueof()的用法及两者的区别
2015/11/16 Javascript
Bootstrap3 datetimepicker控件使用实例
2016/12/13 Javascript
jquery replace方法去空格
2017/05/08 jQuery
zTree jQuery 树插件的使用(实例讲解)
2017/09/25 jQuery
vue.js开发实现全局调用的MessageBox组件实例代码
2017/11/22 Javascript
解决vue 更改计算属性后select选中值不更改的问题
2018/03/02 Javascript
webpack 最佳配置指北(推荐)
2020/01/07 Javascript
js+audio实现音乐播放器
2020/09/13 Javascript
微信小程序弹窗禁止页面滚动的实现代码
2020/12/30 Javascript
对pandas replace函数的使用方法小结
2018/05/18 Python
Python之NumPy(axis=0 与axis=1)区分详解
2019/05/27 Python
通过pycharm使用git的步骤(图文详解)
2019/06/13 Python
Python使用指定端口进行http请求的例子
2019/07/25 Python
Python 3 判断2个字典相同
2019/08/06 Python
用pip给python安装matplotlib库的详细教程
2021/02/24 Python
HTML5 textarea高度自适应的两种方案
2020/04/08 HTML / CSS
北美三大旅游网站之一:Travelocity
2017/08/12 全球购物
StubHub新西兰:购买和出售你的门票
2019/04/22 全球购物
世界上最受欢迎的钓鱼诱饵:Rapala
2019/05/02 全球购物
一些Unix笔试题和面试题
2012/09/25 面试题
测绘工程专业求职信
2014/07/15 职场文书
授权委托书公证
2014/09/14 职场文书
开展批评与自我批评发言材料
2014/10/17 职场文书
党员民主评议个人总结
2014/10/20 职场文书
2014年会计工作总结
2014/11/27 职场文书
优秀教师单行材料
2014/12/16 职场文书
六年级学生期末评语
2014/12/26 职场文书
道士塔读书笔记
2015/06/30 职场文书
创业计划书之零食店(进口)
2019/09/24 职场文书