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


Posted in Javascript onDecember 22, 2014

本文实例讲述了Jquery实现图片预加载与延时加载的方法。分享给大家供大家参考。具体分析如下:

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

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. 默认情况下处于等待状态, 直到用户滚动到窗口上图片所在位置. 在灰色占位图片被点击之前阻止加载图片, 你可以这样做:

$("img").lazyload({

 placeholder : "img/grey.gif",

 event : "click"

});

使用特效

当图片完全加载的时候, 插件默认地使用 show() 方法来将图显示出来. 其实你可以使用任何你想用的特效来处理. 下面的代码使用 FadeIn 效果. 这是效果演示页面.

$("img.lazy").lazyload({ 

    effect : "fadeIn"

});

图片在容器里面

你可以将插件用在可滚动容器的图片上, 例如带滚动条的 DIV 元素. 你要做的只是将容器定义为 jQuery 对象并作为参数传到初始化方法里面. 这是水平滚动演示页面和垂直滚动的演示页面.

#container {

    height: 600px;

    overflow: scroll;

} 

$("img.lazy").lazyload({         

     container: $("#container")

});

当图片不顺序排列

滚动页面的时候, Lazy Load 会循环为加载的图片. 在循环中检测图片是否在可视区域内. 默认情况下在找到第一张不在可见区域的图片时停止循环. 图片被认为是流式分布的, 图片在页面中的次序和 HTML 代码中次序相同. 但是在一些布局中, 这样的假设是不成立的. 不过你可以通过 failurelimit 选项来控制加载行为.

$("img.lazy").lazyload({ 

    failure_limit : 10

});

将 failurelimit 设为 10 令插件找到 10 个不在可见区域的图片是才停止搜索. 如果你有一个猥琐的布局, 请把这个参数设高一点.

延迟加载图片

Lazy Load 插件的一个不完整的功能, 但是这也能用来实现图片的延迟加载. 下面的代码实现了页面加载完成后再加载. 页面加载完成 5 秒后, 指定区域内的图片会自动进行加载. 这是延迟加载演示页面.

$(function() {          

    $("img:below-the-fold").lazyload({

        event : "sporty"

    });

});

$(window).bind("load", function() { 

    var timeout = setTimeout(function() {$("img.lazy").trigger("sporty")}, 5000);

});

加载隐藏的图片

可能在你的页面上埋藏可很多隐藏的图片. 比如插件用在对列表的筛选, 你可以不断地修改列表中各条目的显示状态. 为了提升性能, Lazy Load 默认忽略了隐藏图片. 如果你想要加载隐藏图片, 请将 skip_invisible 设为 false

$("img.lazy").lazyload({ 

    skip_invisible : false

});

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
许愿墙中用到的函数
Oct 07 Javascript
JQuery实现绚丽的横向下拉菜单
Dec 19 Javascript
jQuery+css实现的切换图片功能代码
Jan 27 Javascript
给angular加上动画效遇到的问题总结
Feb 17 Javascript
Vue.js创建Calendar日历效果
Nov 03 Javascript
微信小程序实现给循环列表添加点击样式实例
Apr 26 Javascript
详解vue.js移动端导航navigationbar的封装
Jul 05 Javascript
一个Js文件函数中调用另一个Js文件函数的方法演示
Aug 14 Javascript
深入浅出webpack之externals的使用
Dec 04 Javascript
jQuery EasyUI 折叠面板accordion的使用实例(分享)
Dec 25 jQuery
vue 根据数组中某一项的值进行排序的方法
Aug 30 Javascript
浅谈vue项目打包优化策略
Sep 29 Javascript
javascript定义变量时加var与不加var的区别
Dec 22 #Javascript
javascript操作字符串的原生方法
Dec 22 #Javascript
JavaScript动态创建link标签到head里的方法
Dec 22 #Javascript
javascript中Date对象的getDay方法使用指南
Dec 22 #Javascript
原生javaScript实现图片延时加载的方法
Dec 22 #Javascript
使用JavaScript链式编程实现模拟Jquery函数
Dec 21 #Javascript
使用jQuery简单实现模拟浏览器搜索功能
Dec 21 #Javascript
You might like
php &amp;&amp; 逻辑与运算符使用说明
2010/03/04 PHP
PHP中redis的用法深入解析
2014/02/20 PHP
php实现的漂亮分页方法
2014/04/17 PHP
php常量详细解析
2015/10/27 PHP
PHP怎样用正则抓取页面中的网址
2016/08/09 PHP
Yii针对添加行的增删改查操作示例
2016/10/18 PHP
根据分辨率不同,调用不同的css文件
2006/08/25 Javascript
javascript 四则运算精度修正函数代码
2010/05/31 Javascript
jquery判断checkbox(复选框)是否被选中的代码
2010/10/20 Javascript
自用js开发框架小成 学习js的朋友可以看看
2010/11/16 Javascript
jQuery+.net实现浏览更多内容(改编php版本)
2013/03/28 Javascript
jquery按回车提交数据的代码示例
2013/11/05 Javascript
js中回调函数的学习笔记
2014/07/31 Javascript
教你如何使用node.js制作代理服务器
2014/11/26 Javascript
jQuery中ready事件用法实例
2015/01/19 Javascript
JavaScript输出所选择起始与结束日期的方法
2017/07/12 Javascript
React根据宽度自适应高度的示例代码
2017/10/11 Javascript
NodeJs实现简易WEB上传下载服务器
2019/08/10 NodeJs
Python处理Excel文件实例代码
2017/06/20 Python
Python文件操作之合并文本文件内容示例代码
2017/09/19 Python
运行django项目指定IP和端口的方法
2018/05/14 Python
Python中使用遍历在列表中添加字典遇到的坑
2019/02/27 Python
Python安装Flask环境及简单应用示例
2019/05/03 Python
Python 正则表达式爬虫使用案例解析
2019/09/23 Python
python传到前端的数据,双引号被转义的问题
2020/04/03 Python
详解基于Facecognition+Opencv快速搭建人脸识别及跟踪应用
2021/01/21 Python
带你认识HTML5中的WebSocket
2015/05/22 HTML / CSS
Adobe Html5 Extension开发初体验图文教程
2017/11/14 HTML / CSS
机械系大学毕业生推荐信
2013/11/27 职场文书
会议邀请书范文
2014/02/02 职场文书
摄影专业毕业生求职信
2014/03/13 职场文书
2014年工会工作总结
2014/11/12 职场文书
2015年高校辅导员工作总结
2015/04/20 职场文书
如何使用CocosCreator对象池
2021/04/14 Javascript
评测 | 大屏显示带收音机的高端音箱,JBL TUNE2便携式插卡音箱实测
2021/04/24 无线电
Python基础 括号()[]{}的详解
2021/11/07 Python