jquery实现图片预加载0 [8 D" V; |/ W( z" t$ i! |
js代码0 ?! z/ f, G* a9 x& \4 C" B
$(function(){ loadimg(); function loadimg(url,callback){ var img = new image(); img.onload = function(){ img.onload = null; callback(img); } img.src=url; img.width =202; img.height = 202; img.attr(defaulturl,../images/img.png); if(){} } function addimg(img){ $(img).appendto($(.imgload li)) } }) 7 t+ l1 S$ Z. E+ q6 ^' h: N$ b- I7 g; z6 _
html:
j7 q, H# a/ ?# n6 ^3 [( f2 B<!doctype html> <html lang=en> <head> <meta charset=utf-8> <title>图片预加载</title> <link rel=stylesheet type=text/css href=css/index.css> <script type=text/javascript src=js/jquery-1.8.3.min.js></script> <script type=text/javascript src=js/index.js></script> </head> <body> <div class=imgload> <ul> <li class=fl></li> <li class=fl></li> <li class=fl></li> <li class=fl></li> <li class=fl></li> <li class=fl></li> <li class=fl></li> <li class=fl></li> <li class=fl></li> </ul> </div> </body> </html> , X( G7 l1 a$ T4 w
其他实例
( `' c3 k+ y/ |' n W7 m# Xfunction loadimg(arr,funloading,funonload,funonerror){ var numloaded=0, numerror=0, isobject=object.prototype.tostring.call(arr)===[object object] ? true : false; var arr=isobject ? arr.get() : arr; for(a in arr){ var src=isobject ? $(arr[a]).attr(data-src) : arr[a]; preload(src,arr[a]); } function preload(src,obj){ var img=new image(); img.onload=function(){ numloaded++; funloading && funloading(numloaded,arr.length,src,obj); funonload && numloaded==arr.length && funonload(numerror); }; img.onerror=function(){ numloaded++; numerror++; funonerror && funonerror(numloaded,arr.length,src,obj); } img.src=src; } }
" r1 Z2 p4 x' ~, f1 `5 K/ m$ e# f, |参数说明:4 w ?$ {0 Y( K7 A7 E) s" \
arr:可以是存放图片路径的一个数组,也可以是选取到的img的jquery对象;2 X$ P9 g; N# l& G5 o
funloading:每一个单独的图片加载完成后执行的操作;
8 T! L; ~, ?' i( D/ i funonload:全部图片都加载完成后的操作;
+ R' N- a& p$ k& [ funonerror:单个图片加载出错时的操作。
' h: O% b9 R3 X8 q懒加载,8 I* G$ s& L c; s" _
var imgonload=function(errors){ /*errors:加载出错的图片数量;*/ console.log(loaded,+errors+ images loaded error!); } var funloading=function(n,total,src,obj){ /* n:已加载完成的数量; total:总共需加载的图片数量; src:当前加载完成的图片路径; obj:当loadimg函数中传入的arr为存放图片路径的数组时,obj=src,是图片路径, 当arr为jquery对象时,obj是当前加载完成的img dom对象。 */ console.log(n+of+total+ pic loaded.,src); var newimg = document.createelement(img); newimg.src=src; $(body).append(newimg).fadein(); } var funloading_obj=function(n,total,src,obj){ console.log(n+of+total+ pic loaded.,src); $(obj).attr(src,src); $(obj).fadein(200); } var funonerror=function(n,total,src,obj){ console.log(the +n+st img loaded error!); }
) L i/ n. a: t3 z调试用例
9 @! }( M8 @& y6 q8 oconsole.log(loading...); loadimg($(img),funloading_obj,imgonload,funonerror); /*loadimg([, , , , ],funloading,imgonload,funonerror);*/ 5 X2 z% L4 @, X4 o* T- Z D/ ?
4 W9 e4 B, n& v, F更多网页制作信息请查看: 网页制作 |
|