您现在的位置: 万盛学电脑网 >> 程序编程 >> 脚本专题 >> javascript >> 正文

Jquery实现图片的预加载与延时加载

作者:佚名    责任编辑:admin    更新时间:2022-06-22

 有很多项目经常会需要判断图片加载完成后执行相应的操作,或者需要图片延迟加载,网上虽然已经有很不错的插件,但要为这些效果还得单独加载一个插件的话总感觉有点不舒服,干脆自己写了个方法:

 代码如下  

 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.com/20120619/9607634_212642465144_2.jpg",
   "/20120531/1670912_103610084349_2.jpg",
   "/20120616/4952071_130629530136_2.jpg",
   "/20120610/1723580_105037029000_2.jpg",
   "http://pic22.nipic.com/20120617/2572038_125013326121_2.jpg"
  ],funloading,imgonload,funOnError);*/


上面算是原生态写法了,下面我们介绍一个基于Lazy Load, 延迟加载图片的 jQuery 插件

Lazy Load 依赖于 jQuery. 请将下列代码加入页面 head 区域:

 代码如下   <script src="jquery.js" type="text/javascript"></script>
<script src="jquery.lazyload.js" type="text/javascript"></script>

你必须修改 HTML 代码. 在 src 属性中设置展位符图片, demo 页面使用 1x1 像素灰色 GIF 图片. 并且需要将真实图片的 URL 设置到 data-original 属性. 这里可以定义特定的 class 以获得需要延迟加载的图片对象. 通过这种方法你可以简单地控制插件绑定.

 代码如下   <img class="lazy" src="img/grey.gif" data-original="img/example.jpg"  width="640" heigh="480">

处理图片的代码如下.

 代码如下   $("img.lazy").lazyload();

这将使所有 class 为 lazy 的图片将被延迟加载. 可以参考基本选项 demo

设置敏感度
几乎所有浏览器的 JavaScript 都是激活的. 然而可能你仍希望能在不支持 JavaScript 的客户端展示真实图片. 当浏览器不支持 JavaScript 时优雅降级, 你可以将真实的图片片段在写 <noscript> 标签内.

 代码如下   <img class="lazy" src="img/grey.gif" data-original="img/example.jpg"  width="640" heigh="480">
<noscript><img src="img/example.jpg" width="640" heigh="480"></noscript>

可以通过 CSS 隐藏占位符.

 代码如下   .lazy {
  display: none;
}

在支持 JavaScript 的浏览器中, 你必须在 DOM ready 时将占位符显示出来, 这可以在插件初始化的同时完成.

 代码如下   $("img.lazy").show().lazyload();

这些都是可选的, 但如果你希望插件平稳降级这些都是应该做的.

设置敏感度
默认情况下图片会出现在屏幕时加载. 如果你想提前加载图片, 可以设置 threshold 选项, 设置 threshold 为 200 令图片在距离屏幕 200 像素时提前加载.

 代码如下   $("img.lazy").lazyload({ threshold : 200 });

占位图片
你还可以设定一个占位图片并定义事件来触发加载动作. 这时需要为占位图片设定一个 URL 地址. 透明, 灰色和白色的 1x1 象素的图片已经包含在插件里面.

事件触发加载
事件可以是任何 jQuery 时间, 如: click 和 mouseover. 你还可以使用自定义的事件, 如: sporty 和 foobar. 默认情况下处于等待状态, 直到用户滚动到窗口上图片所在位置. 在灰色占位图片被点击之前阻止加载图片, 你可以这样做: