这篇文章主要介绍了使用jquery实现的一个图片加载插件,同时讲解了图片加载的原理,还有无阻塞加载广告的功能哦,需要的朋友可以参考下

图片加载也称懒加载,通常应用于图片比较多的网页,如果一个页面图片比较多,且页面高度或宽度有好几屏,页面初次加载时,只显示可视区域的图片,当页面的时候,图片进入了可视区域再进行加载,这样可以显著的提高页面的加载速度,更少的图片并发请求数也可以减轻服务器的压力。如果用户仅仅在首屏停留,还可以节省流量。如果TAB中的图片较多,也同样可以应用于TAB中,当触发TAB时再进行图片的加载。

图片加载的原理比较简单,先将图片的真实地址缓存在一个自定义的属性(lazy-src)中,而src地址使用一个1×1的全的占位图片来代替,当然占位图片也可以是其他的图片。

<img src="images/placeholder.png"  lazy-src="images/realimg.jpg" />

因为是使用javascript来加载图片,如果用户禁用了javascript,可以设置一个替代的方案。

<img src="images/placeholder.png"  lazy-src="images/realimg.jpg" alt="" />
<noscript><img src="images/realimg.jpg"  alt="" /></noscript>

页面初次加载时获取图片在页面中的位置并缓存(每次取offset的值会引发页面的reflow),计算出可视区域,当图片的位置出现在可视区域中,将src的值替换成真实的地址,此时图片就开始加载了。

当页面的时候,再判断图片已经缓存的位置值是否出现在可视区域内,进行替换src加载。当所有的图片都加载完之后,将相应的触发事件卸载,避免重复操作引起的内存泄漏。将整个窗口看成是一个大容器,那么也可以在页面中设置一个小容器,在小容器中也同样可以实现图片的加载。

下面是实现的代码,我写成了jQuery插件。


(function( $ ){
$.fn.imglazyload = function( options ){
 var o = $.extend({
attr: 'lazy-src',
container  :  window, 
event :  'scroll',
fadeIn  : false,  
threshold  :  0, 
vertical  :  true 
 }, options ),

event = o.event,
vertical = o.vertical,
container = $( o.container ),
threshold = o.threshold, 
// 将jQuery对象转换成DOM数组便于操作
elems = $.makeArray( $(this) ),
dataName = 'imglazyload_offset',
OFFSET = vertical ? 'top' : 'left',
SCROLL = vertical ? 'scrollTop' : 'scrollLeft', 
winSize = vertical ? container.height() : container.width(),
scrollCoord = container[ SCROLL ](),
docSize = winSize + scrollCoord;

 // 加载的触发器 
 var trigger = {

init : function( coord ){
 return coord >= scrollCoord &&
  coord <= ( docSize + threshold );
},

scroll : function( coord ){
 var scrollCoord = container[ SCROLL ]();
 return coord >= scrollCoord &&
  coord <= ( winSize + scrollCoord + threshold );
},

resize : function( coord ){
 var scrollCoord = container[ SCROLL ](),
winSize = vertical ?
  container.height() :
  container.width();
 return coord >= scrollCoord &&
coord <= ( winSize + scrollCoord + threshold );
}
 };

 var loader = function( triggerElem, event ){
var i = 0,
 isCustom = false,
 isTrigger, coord, elem, $elem, lazySrc;

// 自定义事件只要触发即可,无需再判断
if( event ){
 if( event !== 'scroll' && event !== 'resize' ){
isCustom = true;
 }
}
else{
 event = 'init';
}

for( ; i < elems.length; i++ ){ 
 isTrigger = false;
 elem = elems[i];
 $elem = $( elem );
 lazySrc = $elem.attr( o.attr );

 if( !lazySrc || elem.src === lazySrc ){
continue;
 }
 // 先从缓存获取offset值,缓存中没有才获取计算值,
 // 将计算值缓存,避免重复获取引起的reflow
 coord = $elem.data( dataName );

 if( coord === undefined ){
coord = $elem.offset()[ OFFSET ];
$elem.data( dataName, coord );
 }

 isTrigger = isCustom || trigger[ event ]( coord ); 

 if( isTrigger ){
// 加载图片
elem.src = lazySrc;
if( o.fadeIn ){
 $elem.hide().fadeIn();
}
// 移除缓存
$elem.removeData( dataName );
// 从DOM数组中移除该DOM
elems.splice( i--, 1 );
 }
}

// 所有的图片加载完后卸载触发事件
if( !elems.length ){
 if( triggerElem ){
triggerElem.unbind( event, fire );
 }
 else{
container.unbind( o.event, fire );
 }
 $( window ).unbind( 'resize', fire );
 elems = null;
}

 };

 var fire = function( e ){
loader( $(this), e.type );
 };

 // 绑定事件
 container = event === 'scroll' ? container : $( this ); 
 container.bind( event, fire );
 $( window ).bind( 'resize', fire );

 // 初始化
 loader();

 return this;
};

})( jQuery );


调用:


$( 'img' ).imglazyload({
 event : 'scroll',
 attr : 'lazy-src'
});

默认的调用可以省略所有参数。
$( 'img' ).imglazyload();

图片加载的插件API说明:

attr string
存放图片真实地址的属性名,与HTML对应,默认是lazy-src。

container dom & selector
默认的容器为window,可自定义容器。

event stirng
触发图片加载的事件类型,默认为window.onscroll事件

fadeIn boolean
是否使用jQuery的fadeIn效果来显示,默认是false。

threshold number
页面到离图片还有指定距离的时候就进行加载,默认是0。

vertical boolean
是否横向,默认为true(纵向)。

loadScript(增强版的功能) boolean
是否无阻塞加载javascript广告图片,默认为false。

最新资讯
美团点评股价重回发行价:临近上市1周年 市值超4000亿港元

美团点评股价重回发行

在美团点评将迎来上市一周年,及明日要公布半年报之际,美
消息称大众汽车CEO对收购特斯拉股份感兴趣

消息称大众汽车CEO对

路透社今日援引德国《经理人》杂志的报道称,大众汽车CE
蔚来9月底前裁员1200人 造车新势力如何过冬?

蔚来9月底前裁员1200

8月22日,蔚来汽车创始人李斌对全体员工下发内部信,称9月
任正非批系统部没做好不放权 称四个代表处请示太多

任正非批系统部没做好

近日,华为创始人任正非在运营商BG组织变革研讨会上表示
中兴:“130亿定增募资方案”过审 将强化5G芯片研发

中兴:“130亿定增募资

今晚,中兴通讯发布公告,关于非公开发行A股股票申请获得
vivo首款5G手机发布 称已申请超2000项5G专利

vivo首款5G手机发布

vivo今日发布了其首款5G手机IQOO Pro,售价3798元起。IQ
最新文章
Javascript读写cookie的实例源码

Javascript读写cookie

今天小编就为大家分享一篇关于Javascript读写cookie的
微信小程序登录session的使用

微信小程序登录sessio

这篇文章主要介绍了微信小程序登录session的使用,小编
JavaScript中this用法学习笔记

JavaScript中this用法

在本篇文章里小编给大家分享了关于JavaScript中this用
nodejs微信开发之授权登录+获取用户信息

nodejs微信开发之授权

这篇文章主要介绍了nodejs微信开发之授权登录+获取用
nodejs微信开发之自动回复的实现

nodejs微信开发之自动

这篇文章主要介绍了nodejs微信开发之自动回复的实现,文
node微信开发之获取access_token+自定义菜单

node微信开发之获取ac

这篇文章主要介绍了node微信开发之获取access_token+