用jQuery模拟页面加载进度条的实现代码


Posted in Javascript onDecember 19, 2011

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

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

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

CSS

*{margin:0;padding:0;font-size:12px} 
.loading{position:relative;top:0;left:0} 
.text input{float:left;color:#fff;height:32px;line-height:34px;padding:0 15px;background:#A70000;border:0} 
.jindu{float:left;margin-left:14px;color:#fff;width:150px;height:32px;line-height:32px;background:#000;position:relative} 
.jindu b{color:#A70000;font-size:0px;border-width:10px;border-color:transparent transparent transparent #A70000;border-style:dotted dotted dotted solid;position:absolute;left:-16px;top:5px} 
.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="text"><input type="button" value="正在初始化"></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){ 
$('.loading .jindu2').animate({width:c+'px'},500,function(){ 
$('.loading input').val(a); 
$('.loading font').text(b); 
$('.loading').animate({top:'-32px'},1000,function(){ 
alert('页面加载完毕'); 
}); 
}); 
}else{ 
$('.loading .jindu2').animate({width:c+'px'},500,function(){ 
$('.loading input').val(a); 
$('.loading 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 相关文章推荐
列表内容的选择
Jun 30 Javascript
在JavaScript中通过URL传递汉字的方法
Apr 09 Javascript
JavaScript 以对象为索引的关联数组
May 19 Javascript
详解jquery中$.ajax方法提交表单
Nov 03 Javascript
使用Chart.js图表库制作漂亮的响应式表单
Oct 28 Javascript
多个上传文件用js验证文件的格式和大小的方法(推荐)
Mar 09 Javascript
input file样式修改以及图片预览删除功能详细概括(推荐)
Aug 17 Javascript
laravel5.4+vue+element简单搭建的示例代码
Aug 29 Javascript
node.js 核心http模块,起一个服务器,返回一个页面的实例
Sep 11 Javascript
解决Vue不能检测数组或对象变动的问题
Feb 24 Javascript
对VUE中的对象添加属性
Sep 18 Javascript
详解Element-UI中上传的文件前端处理
Aug 07 Javascript
javascript管中窥豹 形参与实参浅析
Dec 17 #Javascript
jquery focus(fn),blur(fn)方法实例代码
Dec 16 #Javascript
JS获取整个页面文档的实现代码
Dec 15 #Javascript
jQuery版仿Path菜单效果
Dec 15 #Javascript
cnblogs 代码高亮显示后的代码复制问题解决实现代码
Dec 14 #Javascript
js 可拖动列表实现代码
Dec 13 #Javascript
使用Mootools动态添加Css样式表代码,兼容各浏览器
Dec 12 #Javascript
You might like
日本十大科幻动漫 宇宙骑士垫底,第一已成经典
2020/03/04 日漫
使用PHP 5.0创建图形的巧妙方法
2010/10/12 PHP
php中定时计划任务的实现原理
2013/01/08 PHP
smarty缓存用法分析
2014/12/16 PHP
6个超实用的PHP代码片段
2015/08/10 PHP
JQueryEasyUI datagrid框架的进阶使用
2013/04/08 Javascript
常见浏览器多长时间会提示“脚本运行时间过长”总结
2014/04/29 Javascript
Javascript动画的实现原理浅析
2015/03/02 Javascript
JS获得图片alt信息的方法
2015/04/01 Javascript
使用jQuery处理AJAX请求的基础学习教程
2016/05/10 Javascript
jquery html动态添加的元素绑定事件详解
2016/05/24 Javascript
前端开发之CSS原理详解
2017/03/11 Javascript
jQuery EasyUI 选项卡面板tabs的使用实例讲解
2017/12/25 jQuery
nodejs 最新版安装npm 的使用详解
2018/01/18 NodeJs
jQuery简单实现根据日期计算星期几的方法
2019/01/09 jQuery
通过说明与示例了解js五种设计模式
2019/06/17 Javascript
angular6开发steps步骤条组件
2019/07/04 Javascript
微信小程序中网络请求缓存的解决方法
2019/12/29 Javascript
python的常见命令注入威胁
2013/02/18 Python
Python定时发送消息的脚本:每天跟你女朋友说晚安
2018/10/21 Python
对python:threading.Thread类的使用方法详解
2019/01/31 Python
详解python中init方法和随机数方法
2019/03/13 Python
python字符串和常用数据结构知识总结
2019/05/21 Python
基于Python实现ComicReaper漫画自动爬取脚本过程解析
2019/11/11 Python
Django+Uwsgi+Nginx如何实现生产环境部署
2020/07/31 Python
Python2及Python3如何实现兼容切换
2020/09/01 Python
Skyscanner阿联酋:全球领先的旅游搜索平台
2017/11/25 全球购物
美国在线宠物商店:Chewy
2019/01/12 全球购物
了解AppleTalk协议吗
2014/04/01 面试题
Python里面search()和match()的区别
2016/09/21 面试题
给物业的表扬信
2014/01/21 职场文书
大学社团活动策划书
2014/01/26 职场文书
学习十八大的心得体会
2014/09/01 职场文书
复活读书笔记
2015/06/29 职场文书
话题作文之生命的旋律
2019/12/17 职场文书
使用ORM新增数据在Mysql中的操作步骤
2021/07/26 MySQL