博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JQuery实现图片的预加载与延时加载
阅读量:7156 次
发布时间:2019-06-29

本文共 1912 字,大约阅读时间需要 6 分钟。

转自:http://www.rjboy.cn/?p=1002

 

预加载,

Js代码  
  1. function loadimg(arr,funLoading,funOnLoad,funOnError){  
  2.     var numLoaded=0,  
  3.     numError=0,  
  4.     isObject=Object.prototype.toString.call(arr)==="[object Object]" ? true : false;  
  5.    
  6.     var arr=isObject ? arr.get() : arr;  
  7.     for(a in arr){  
  8.         var src=isObject ? $(arr[a]).attr("data-src") : arr[a];  
  9.         preload(src,arr[a]);  
  10.     }  
  11.    
  12.     function preload(src,obj){  
  13.         var img=new Image();  
  14.         img.οnlοad=function(){  
  15.             numLoaded++;  
  16.             funLoading && funLoading(numLoaded,arr.length,src,obj);  
  17.             funOnLoad && numLoaded==arr.length && funOnLoad(numError);  
  18.         };  
  19.         img.οnerrοr=function(){  
  20.             numLoaded++;  
  21.             numError++;  
  22.             funOnError && funOnError(numLoaded,arr.length,src,obj);  
  23.         }  
  24.         img.src=src;  
  25.     }  
  26.    
  27. }  

参数说明:

  arr:可以是存放图片路径的一个数组,也可以是选取到的img的jquery对象;
  funLoading:每一个单独的图片加载完成后执行的操作;
  funOnLoad:全部图片都加载完成后的操作;
  funOnError:单个图片加载出错时的操作。

 

懒加载,

Js代码  
  1. var imgοnlοad=function(errors){  
  2.         /*errors:加载出错的图片数量;*/  
  3.     console.log("loaded,"+errors+" images loaded error!");  
  4. }  
  5.    
  6. var funloading=function(n,total,src,obj){  
  7.         /* 
  8.         n:已加载完成的数量; 
  9.         total:总共需加载的图片数量; 
  10.         src:当前加载完成的图片路径; 
  11.         obj:当loadimg函数中传入的arr为存放图片路径的数组时,obj=src,是图片路径, 
  12.                当arr为jquery对象时,obj是当前加载完成的img dom对象。 
  13.        */  
  14.     console.log(n+"of"+total+" pic loaded.",src);  
  15.     var newimg = document.createElement("img");  
  16.     newimg.src=src;  
  17.     $("body").append(newimg).fadeIn();  
  18. }  
  19.    
  20. var funloading_obj=function(n,total,src,obj){  
  21.     console.log(n+"of"+total+" pic loaded.",src);  
  22.     $(obj).attr("src",src);  
  23.     $(obj).fadeIn(200);  
  24. }  
  25.    
  26. var funOnError=function(n,total,src,obj){  
  27.     console.log("the "+n+"st img loaded Error!");  
  28. }  

 

调试用例,

Js代码  
  1. console.log("loading...");  
  2. loadimg($("img"),funloading_obj,imgonload,funOnError);  
  3. /*loadimg(["http://pic22.nipic.com/20120619/9607634_212642465144_2.jpg", 
  4.          "http://pic21.nipic.com/20120531/1670912_103610084349_2.jpg", 
  5.          "http://pic21.nipic.com/20120616/4952071_130629530136_2.jpg", 
  6.          "http://pic21.nipic.com/20120610/1723580_105037029000_2.jpg", 
  7.          "http://pic22.nipic.com/20120617/2572038_125013326121_2.jpg" 
  8.         ],funloading,imgonload,funOnError);*/  

 

 

转载地址:http://iehgl.baihongyu.com/

你可能感兴趣的文章
Python模拟新浪微博登录
查看>>
zabbix 代理(agent)端详细安装配置一
查看>>
常见证书格式及相互转换
查看>>
Linux 安装python 模块及库
查看>>
CentOS 配置网关服务器
查看>>
如何在rhel5环境下配置网卡绑定
查看>>
NodeJS基础-9 HTTP小爬虫
查看>>
F5 LTM1500诡异的硬盘故障(连载二)
查看>>
SEO系列一:SEO是什么?SEO有什么意义?
查看>>
快递小哥逆袭自传:用了6年时间做到了IT部门主管
查看>>
程序coredump原因
查看>>
button只能点击一次的限制
查看>>
回调函数的理解
查看>>
STM32F767IGT6上电多次重启问题查找与解决
查看>>
hadoop
查看>>
Getting Started in OS Development开发自己的操作系统
查看>>
HEX文件格式
查看>>
JVM调优之:内存模型
查看>>
1.3列出文件属性 ls
查看>>
easyui filebox文件类型判断
查看>>