用jQuery模擬頁面加載進(jìn)度條的實(shí)現(xiàn)代碼
更新時(shí)間:2011年12月19日 22:03:41 作者:
因?yàn)槲覀儫o法通過任何方法獲取整個(gè)頁面的大小和當(dāng)前加載了多少,所以想制作一個(gè)加載進(jìn)度條的唯一辦法就是模擬。那要怎么模擬呢
因?yàn)槲覀儫o法通過任何方法獲取整個(gè)頁面的大小和當(dāng)前加載了多少,所以想制作一個(gè)加載進(jìn)度條的唯一辦法就是模擬。那要怎么模擬呢?
我們知道,頁面是從上往下執(zhí)行的,也就是說我們可以大致估算出在頁面的某個(gè)位置加載了多少,而后用jq模擬出一個(gè)進(jìn)度條來顯示。
首先我們先畫一個(gè)進(jìn)度條的樣子,也就是上圖圖中的樣子,這個(gè)不用過多說明,自己看代碼
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">頁面總進(jìn)度 <font>0</font>%</div>
</div>
</div>
這時(shí)候注意了,我們要引用jquery庫,引用的位置不是在head區(qū)域,而是緊接著html代碼下面寫。為什么要這樣,因?yàn)闃邮轿覀兎舎ead里的原因是保證頁面加載第一步就把樣式加載好,這樣頁面不會(huì)亂。而JS則不需要,再加上頁面上大的文件主要也就是js,所以放在body里加載js是為了進(jìn)度條考慮。
進(jìn)度條畫好了,jquery引用了,我們現(xiàn)在要寫個(gè)方法,也就是可以讓進(jìn)度條動(dòng)起來
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);
});
}
};
這里我寫了個(gè)loading(a,b),兩個(gè)參數(shù)分別是顯示加載內(nèi)容提示信息和加載進(jìn)度百分比,然后,我用了其他幾個(gè)js庫做加載進(jìn)度測(cè)試
<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下載地址:在線演示 點(diǎn)擊下載
我們知道,頁面是從上往下執(zhí)行的,也就是說我們可以大致估算出在頁面的某個(gè)位置加載了多少,而后用jq模擬出一個(gè)進(jìn)度條來顯示。
首先我們先畫一個(gè)進(jìn)度條的樣子,也就是上圖圖中的樣子,這個(gè)不用過多說明,自己看代碼
CSS
復(fù)制代碼 代碼如下:
*{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
復(fù)制代碼 代碼如下:
<div class="loading">
<div class="text"><input type="button" value="正在初始化"></div>
<div class="jindu">
<b></b>
<div class="jindu2"></div>
<div class="text">頁面總進(jìn)度 <font>0</font>%</div>
</div>
</div>
這時(shí)候注意了,我們要引用jquery庫,引用的位置不是在head區(qū)域,而是緊接著html代碼下面寫。為什么要這樣,因?yàn)闃邮轿覀兎舎ead里的原因是保證頁面加載第一步就把樣式加載好,這樣頁面不會(huì)亂。而JS則不需要,再加上頁面上大的文件主要也就是js,所以放在body里加載js是為了進(jìn)度條考慮。
進(jìn)度條畫好了,jquery引用了,我們現(xiàn)在要寫個(gè)方法,也就是可以讓進(jìn)度條動(dòng)起來
復(fù)制代碼 代碼如下:
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);
});
}
};
這里我寫了個(gè)loading(a,b),兩個(gè)參數(shù)分別是顯示加載內(nèi)容提示信息和加載進(jìn)度百分比,然后,我用了其他幾個(gè)js庫做加載進(jìn)度測(cè)試
復(fù)制代碼 代碼如下:
<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下載地址:在線演示 點(diǎn)擊下載
您可能感興趣的文章:
- jQuery實(shí)現(xiàn)可拖動(dòng)進(jìn)度條實(shí)例代碼
- jquery 實(shí)現(xiàn)拖動(dòng)文件上傳加載進(jìn)度條功能
- jquery 簡(jiǎn)單的進(jìn)度條實(shí)現(xiàn)代碼
- 6款新穎的jQuery和CSS3進(jìn)度條插件推薦
- 分享8款優(yōu)秀的 jQuery 加載動(dòng)畫和進(jìn)度條插件
- 基于HTML5 Ajax文件上傳進(jìn)度條如何實(shí)現(xiàn)(jquery版本)
- Jquery進(jìn)度條插件 Progress Bar小問題解決
- Jquery Uploadify上傳帶進(jìn)度條的簡(jiǎn)單實(shí)例
- jQuery 頁面載入進(jìn)度條實(shí)現(xiàn)代碼
- jQuery簡(jiǎn)單實(shí)現(xiàn)提交數(shù)據(jù)出現(xiàn)loading進(jìn)度條的方法
- jQuery實(shí)現(xiàn)的手動(dòng)拖動(dòng)控制進(jìn)度條效果示例【測(cè)試可用】
相關(guān)文章
jQuery Validate 無法驗(yàn)證 chosen-select元素的解決方法
這篇文章主要介紹了jQuery Validate 無法驗(yàn)證 chosen-select元素的解決方法,需要的朋友可以參考下2017-05-05jQuery中noConflict()用法實(shí)例分析
這篇文章主要介紹了jQuery中noConflict()用法,實(shí)例分析了noConflict()的功能、定義及相關(guān)使用技巧,需要的朋友可以參考下2015-02-02jQuery獲取attr()與prop()屬性值的方法及區(qū)別介紹
這篇文章主要介紹了jQuery獲取attr()與prop()屬性值的方法及區(qū)別介紹的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07jQuery+PHP+Ajax實(shí)現(xiàn)動(dòng)態(tài)數(shù)字統(tǒng)計(jì)展示功能
這篇文章主要介紹了jQuery+PHP+Ajax實(shí)現(xiàn)動(dòng)態(tài)數(shù)字統(tǒng)計(jì)展示功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12