返回列表 发新帖

jquery简单实现图片预加载

433.9k 10
swmozowtfl 发表于 2015-7-9 23:19:41|湖北 | 查看全部 阅读模式
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更多网页制作信息请查看: 网页制作

回复|共 10 个

wwzcdenleclv 发表于 2015-11-3 16:44:51|INNA | 查看全部
希望这样的好贴多些,再多些!!!
tohme 发表于 2015-11-3 16:44:26|INNA | 查看全部
我刚来~~~嘿嘿~~此声明最终解释权归本人所有。
GoodyFouppy 发表于 2015-11-3 16:44:20|INNA | 查看全部
挨骂也是幸福~~~
alapScady 发表于 2015-11-3 16:45:08|江西 | 查看全部
手机版的得知互动论坛好强大
Acropozelan 发表于 2015-11-3 16:43:45|美国 | 查看全部
不错的东西 持续关注
gevaemaidovef 发表于 2016-1-15 14:21:35|美国 | 查看全部
因删贴不及时所产生的任何法律(书法,基本法,劳动法,婚姻法,输入法,国际法,今日说法,与台湾关系法及文中涉及或可能涉及以及未及之法,各地治安管理条例)纠纷或责任本人概不负责。
wwzcdenleclv 发表于 2016-1-15 14:21:31|北美地区 | 查看全部
怎么这么跟别人不一样类~
effoggikeftor 发表于 2016-1-15 14:21:11|塞尔维亚 | 查看全部
系统居然怀疑我灌水,我身边又没有水龙头。哦…明白了,身上有一个……
alapScady 发表于 2016-1-15 14:21:55|印度 | 查看全部
还呕像.....
buingeEvineus 发表于 2016-1-15 14:21:33|澳大利亚 | 查看全部
好吧...那你说...

回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

得知互动是一个融创意、设计、开发、营销、生活、互联网于一体的专业交流分享平台。
Copyright © 2026 站长技术交流论坛|互联网技术交流平台|Ai技术交流平台 版权所有 All Rights Reserved. Powered by Discuz! X5.0 鄂ICP备15006301号-5|鄂公网安备 42018502006730号
关灯 在本版发帖 扫一扫添加QQ客服 返回顶部
快速回复 返回顶部 返回列表