jQuery插件图片懒加载lazyload
来自XXX的前言:
什么是ImageLazyLoad技术
在页面上图片比较多的时候,打开一张页面必然引起与服务器大数据量的
交互。尤其是对于高清晰的图片,占的几M的空间。ImageLazyLoad技术就是,当前可见界面的图片是加载进来的,而不可见页面(通过滚动条下拉可
见)中的图片是不加载的,这样势必会引起速度上质的提升。
实现原理:
当图片滚动到可视区时将图片加载进来。
图片不在可视区判断:
(一):图片距离页面顶端的高度 大于 窗口可视区的高度+window滚动条的scrollTop。
(二):图片距离页面顶端的高度+图片自身的高度 小于 window滚动条的scrollTop。
在lazyload中的实现(lazyload源码在后面):
var _this=$(this), //this就是图片
top=win.scrollTop(), //win就是window
imgTop=_this.offset().top,
imgHeight=_this.outerHeight(true); if(top+win.height()>imgTop && imgTop+imgHeight>top){
...(图片在可视区了)
}
使用插件html准备(这是一个最简单的图片懒加载,或许这个已经达到正常需求):
html结构: <div id="box">
<img data-src="http://www.netbian.com/d/file/20150325/41ada82f8c880dc89bdb95e38e8777f4.jpg" src="loading.svg" />
......
<img data-src="http://www.netbian.com/d/file/20140410/875d3e24e25a00761a71c4d46f130da0.jpg" src="loading.svg" />
</div> 解释:先用一张所有的图片(src)加载loading这个图片,然后给img加个data-src的属性,存储着图片本来的路径,然后就等js实现了。
js使用插件:
<script>
$('img').lazyload(/*{
effect:'fadeIn', //默认'fadeIn(淡入)',参数列表['none','fadeIn']
fadeTime: 600, //淡出时间,默认600ms,参数为number类型时间
timeout: 260 //当用户看到图片时,是否立即加载图片,默认'(延迟)260ms',参数列表['none','time(number类型)']
}*/)
</script>
插件源码(兼容ie6):
;(function($){
$.fn.extend({
lazyload:function(Options){
var _this=$(this),
win=$(window),
timer=null, settings=$.extend({
effect: 'fadeIn',
fadeTime: 600,
timeout: 260
},Options); loading(); //开始执行已经到可视区的图片
win.scroll(function(){
settings.timeout=='none' ? loading() : ( clearTimeout(timer),timer=setTimeout(loading,settings.timeout) ) //是否延时加载
}); function loading(){
_this.each(function(){
var _this=$(this),
top=win.scrollTop(),
imgTop=_this.offset().top,
imgHeight=_this.outerHeight(true); if(top+win.height()>imgTop && imgTop+imgHeight>top){
var dSrc=_this.attr('data-src');
if(dSrc==_this.attr('src')) return; //图片已经显示,则返回 $(new Image()).prop('src',dSrc).load(function(){ //替换图片URL
_this.attr('src',dSrc);
settings.effect=='fadeIn' && _this.css('opacity',0).animate({opacity:1},settings.fadeTime)
})
}
})
}
return _this
}
})
})(jQuery);
--------- 平平的分割线 -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
有了来自 @李明夕 的指导,然后就对lazyload进行了改造,添加了函数节流,其实之前的也用到了,只不过不知道专业名称-_-#,不过还是学到不少,函数节流文章链接:http://www.alloyteam.com/2012/11/javascript-throttle/
然后就是添加了事件移除功能,应该是有利于性能优化的。下面是改过后的代码:
;(function($){
$.fn.extend({
lazyload:function(Options){
var gThis=$(this),
win=$(window), throttle=function(fn,delay){ //函数节流,【执行函数,延迟时间】
var timer,
startTime=new Date(); return function(){
clearTimeout(timer); if(!delay && new Date()-startTime>100){ //没有延迟,并判断延迟滚动时间的必须的时间
startTime=new Date();
fn() }else if(delay){
timer=setTimeout(function(){
startTime=new Date();
fn()
}, delay)
}
}
}, settings=$.extend({
effect: 'fadeIn',
fadeTime: 600,
delay: 400
},Options); loading(); //开始便加载已经出现在可视区的图片
win.on( 'scroll.lazyload', throttle(loading, settings.delay) ); function loading(){
if(!gThis.length) return win.off('scroll.lazyload'); //当所有的图片都加载完,移除窗口滚动事件 gThis.each(function(){
var _this=$(this),
top=win.scrollTop(),
imgTop=_this.offset().top,
imgHeight=_this.outerHeight(true); if(top+win.height()>imgTop && imgTop+imgHeight>top){
gThis=gThis.not( _this ); //删除jQuery选择好的元素集合中已经被加载的图片元素 var dSrc=_this.attr('data-src');
$(new Image()).prop('src',dSrc).load(function(){ //替换图片URL
_this.attr('src',dSrc);
settings.effect=='fadeIn' && _this.css('opacity',0).animate({opacity:1},settings.fadeTime)
})
}
})
} return $(this)
}
})
})(jQuery);
Demo地址:http://small.890m.com/lazyload/
jQuery插件图片懒加载lazyload的更多相关文章
- js插件---图片懒加载lazyload
js插件---图片懒加载lazyload 一.总结 一句话总结:使用异常简单,src里面放加载的图片,data-original里面放原图片,不懂的位置去官网或者github找API就好. 1.laz ...
- js插件---图片懒加载echo.js结合 Amaze UI ScrollSpy 使用
js插件---图片懒加载echo.js结合 Amaze UI ScrollSpy 使用 一.总结 一句话总结:图片懒加载echo.js结合 Amaze UI ScrollSpy 使用的效果就是:懒加载 ...
- [js开源组件开发]图片懒加载lazyload
图片懒加载lazyload 前端对请求的一种优化方式,为什么叫懒加载,无从查起,反正我当初一直认为它是滚动加载的一种类型.它主要是以图片或背景在可视区域内时才显示真正的图片,减少src带来的负荷.所以 ...
- 使用jQuery实现图片懒加载原理
原文:https://www.liaoxuefeng.com/article/00151045553343934ba3bb4ed684623b1bf00488231d88d000 在网页中,常常需要用 ...
- jQuery的图片懒加载
jQuery的图片懒加载 function imgLazyLoad(options) { var settings = { Id: $('img'), threshold: 100, effectsp ...
- 插件:★★★ !!!图片懒加载 lazyload.js 、 jquery.scrollLoading.js
插件:图片懒加载 jquery.lazyload.js 2016-3-31 插件说明:http://www.w3cways.com/1765.html (小插件,好用) 下载地址: https://r ...
- 前端实现图片懒加载(lazyload)的两种方式
在实际的项目开发中,我们通常会遇见这样的场景:一个页面有很多图片,而首屏出现的图片大概就一两张,那么我们还要一次性把所有图片都加载出来吗?显然这是愚蠢的,不仅影响页面渲染速度,还浪费带宽.这也就是们通 ...
- 前端性能优化--图片懒加载(lazyload image)
话说前头: 上次写了一篇webpack的学习心得,webpack能做到提升前端的性能,其模块打包最终生成一个或少量的文件能够减少对服务端的请求.除此之外,本次的图片懒加载(当然不仅限于图片,还可以有视 ...
- 前端性能优化成神之路--图片懒加载(lazyload image)
图片懒加载(当然不仅限于图片,还可以有视频,flash)也是一种优化前端性能的方式.使用懒加载可以想要看图片时才加载图片,而不是一次性加载所有的图片,从而在一定程度从减少服务端的请求 什么是懒加载 懒 ...
随机推荐
- ReactNative之Redux详解
用redux有一段时间了,感觉还是有必要把其相关的知识点系统的总结一下的,毕竟好记性不如烂笔头.上篇博客更新了关于<ES6中的迭代器.Generator函数以及Generator函数的异步操作& ...
- Matlab 图论最短路问题模型代码
最短路问题的基本内容 最短路问题研究的是,在一个点与点之间连接形成的网络图中,对应路径赋予一定的权重(可以理解为两点之间的距离),计算任意两点之间如何和走,路径最短的问题.在这里的距离可以理解成各种两 ...
- 目标检测中常提到的IoU和mAP究竟是什么?
看完这篇就懂了. IoU intersect over union,中文:交并比.指目标预测框和真实框的交集和并集的比例. mAP mean average precision.是指每个类别的平均查准 ...
- web前端开发面试题(附答案)-1
1.浏览器中输入url到网页显示,整个过程发生了什么 域名解析 发起tcp三次握手 建立tcp连接之后发起htttp请求 服务器端响应http请求,浏览器得到html代码 浏览器器解析html代码,并 ...
- Java中Synchronized的优化原理
我们知道,从 JDK1.6 开始,Java 对 Synchronized 同步锁做了充分的优化,甚至在某些场景下,它的性能已经超越了 Lock 同步锁.那么就让我们来看看,它究竟是如何优化的. 原本的 ...
- JS/JQuery 禁用超链接a
JS // 禁用超链接元素elem ; document.getElementById(elemID).setAttribute('disabled', 'disabled'); // 启用超链接元素 ...
- Python数据结构 - 利用headp模块寻找最大N个元素并实现优先队列
用headp找到最大最小的N个值 import heapq nums = [1, 8, 2, 23, 7, -4, 18, 23, 42, 37, 2] print(heapq.nlargest(3, ...
- maven私服 nexus 的安装与使用
简介 私服不是Maven的核心概念,它仅仅是一种衍生出来的特殊的Maven仓库.通过建立自己的私服,就可以降低中央仓库负荷.节省外网带宽.加速Maven构建.自己部署构建等,从而高效地使用Maven. ...
- Nebula Graph 技术总监陈恒:图数据库怎么和深度学习框架进行结合?
引子 Nebula Graph 的技术总监在 09.24 - 09.30 期间同开源中国·高手问答的小伙伴们以「图数据库的设计和实践」为切入点展开讨论,包括:「图数据库的存储设计」.「图数据库的计算设 ...
- JavaScript中闭包的使用和各种继承介绍
一.什么是闭包? (1)闭包的概念:a.闭包就是函数嵌套时,让局部变量变成自由变量的环境,是一种让局部变量进化的方式. b.定义在一个函数内部的函数. ...