jQuery简单实现图片预加载
网络编程 2021-07-04 21:47www.168986.cn编程入门
我们在做网站的时候经常会遇到这样的问题一个页面有大量的图片导致页面加载速度缓慢,经常会出现一个白页用户体验很不好。那么如何解决这个问题呢?狼蚁网站SEO优化我来介绍一种在实际应用中经常会使用到的js预加载的方法。
jQuery实现图片预加载
JS代码
$(function(){ loadImg("http://d.hiphotos.baidu./image/pic/item/fd039245d688d43f14f69eff7f1ed21b0ef43b5b.jpg",addImg); 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")) } })
HTML:
<!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>
其他实例
function 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; } }
参数说明
arr可以是存放图片路径的一个数组,也可以是选取到的img的jquery对象;
funLoading每一个单独的图片加载完成后执行的操作;
funOnLoad全部图片都加载完成后的操作;
funOnError单个图片加载出错时的操作。
懒加载,
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!"); }
调试用例
console.log("loading..."); loadimg($("img"),funloading_obj,imgonload,funOnError); /loadimg(["http://pic22.nipic./20120619/9607634_212642465144_2.jpg", "http://pic21.nipic./20120531/1670912_103610084349_2.jpg", "http://pic21.nipic./20120616/4952071_130629530136_2.jpg", "http://pic21.nipic./20120610/1723580_105037029000_2.jpg", "http://pic22.nipic./20120617/2572038_125013326121_2.jpg" ],funloading,imgonload,funOnError);/
以上所述就是本文的全部内容了,希望大家能够喜欢。
上一篇:javascript实现汉字转拼音代码分享
下一篇:jquery滚动到顶部底部代码
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程