Javascript,Jquery实现页面图片预加载百分比展现

如果需要在页面初始加载时显示加载进度。主要是指图片很多的情况下:

可以使用第三方Jquery插件jquery.imgpreload.min.js

调用里面的方法:imgpreload即可,实例如下:

varimgNum=0;

varimages=[];

$(function(){preloadImg();});

//里面有两种方式

functionpreLoadImg(){

//第一种方式:通过dom方法获取页面中的所有img,包括<img>标签和css中的background-image

/*getallimgsthosetagis<img>

varimgs=document.images;

for(vari=0;i<imgs.length;i++){

images.push(imgs[i].src);

}

//getallimagesinstyle

varcssImages=getallBgimages();

for(varj=0;j<cssImages.length;j++){

images.push(cssImages[j]);

}*/

//第二种方式:把所有该网页上用到的图片文件都预先放入一个数组里

$.imgpreload(['images/bg1.jpg','images/bg2.jpg'],function(){

//此处是显示进度百分比时需要用到的背景图,这个可以先加载进去

});

//thenpushallotherimagesinarraytoload

images.push("images/test_1.png");

images.push("images/test_2.png");

images.push("images/test_3.png");

//。。。

images.push("images/test_n.png");

/*这里是真正的图片预加载preload*/

$.imgpreload(images,

{

each:function(){

/*thiswillbecalledaftereachimageloaded*/

varstatus=$(this).data('loaded')?'success':'error';

if(status=="success"){

varv=(parseFloat(++imgNum)/images.length).toFixed(2);

$("#percentShow").html(Math.round(v*100)+"<sup>%</sup>");

}

},

all:function(){

/*thiswillbecalledafterallimagesloaded*/

$("#percentShow").html("100<sup>%</sup>");

$("percentShow").fadeOut(1000);

$(".main").show();

}

});

}

//getallimagesinstyle(此方法引用其他博客的)

functiongetallBgimages(){

varurl,B=[],A=document.getElementsByTagName('*');

A=B.slice.call(A,0,A.length);

while(A.length){

url=document.deepCss(A.shift(),'background-image');

if(url)url=/url\(['"]?([^")]+)/.exec(url)||[];

url=url[1];

if(url&&B.indexOf(url)==-1)B[B.length]=url;

}

returnB;

}

document.deepCss=function(who,css){

if(!who||!who.style)return'';

varsty=css.replace(/\-([a-z])/g,function(a,b){

returnb.toUpperCase();

});

if(who.currentStyle){

returnwho.style[sty]||who.currentStyle[sty]||'';

}

vardv=document.defaultView||window;

returnwho.style[sty]||

dv.getComputedStyle(who,"").getPropertyValue(css)||'';

}

Array.prototype.indexOf=Array.prototype.indexOf||

function(what,index){

index=index||0;

varL=this.length;

while(index<L){

if(this[index]===what)returnindex;

++index;

}

return-1;

}

这样就能在页面图片很多,且网速很慢的情况下给予用户一个百分比提示。

在做这个之前,由于每次本地测试加载都很快,百分比瞬间到100%然后消失,为了看上去有那么一回事,我还写了一个伪百分比进度条,仅供玩耍:

vart=window.setTimeout("preLoad()",100);

functionpreLoad(){

$("#loadingdiv").animate({width:step+"px"},50).text(step+"%");

step+=1;

if(step<=100){

t=window.setTimeout("preLoad()",100);

}else{

clearTimeout(t);

$("#loading").fadeOut(1000);

$("#preloadImg").fadeOut(1000);

$(".main").show();

}

(这是一个页面初始化完成之后,在页面上有一个模拟百分比不断增长的过程,到100%后消失进度条,显示主页面,不过跟实际页面加载没任何关系,可以忽悠不懂且有想要此功能的人,哈哈)

转来的。。。

相关推荐