JavaScript图片懒加载,包含加载成功回调,失败回调

一、什么是图片懒加载?

当浏览器打开一个页面的时候,img标签先显示占位图(loading.gif),页面滚动,当该元素出现在浏览器的可视区域范围内时,img元素开始进行真实图片路径加载,并显示出来。这就是图片懒加载。

二、为什要使用这个技术?

比如一个页面中有很多图片,如淘宝、京东首页等等,如果一上来就发送这么多请求,页面加载就会很漫长。网络性能上:一开启页面就发送百八十个请求,服务器可能就吃不消了。比如一个页面有50张图片,就有50个图片请求,同时有100个人访问的话,就是5000个请求。

==总结:不仅可以减轻服务器的压力,而且可以让页面更快地呈现在用户面前(用户体验好)。==

三、怎么实现?

预热

1、页面中的img元素,如果没有src属性或者src属性没有设置值,浏览器就不会发出请求去下载图片 一旦通过JavaScript或者jQuery或DOM操作设置了图片路径,浏览器才会送请求,进行图片的下载。

2、如何获取图片真实的请求路径,先把真的路径存在元素的“data-original”(这个值可以自定义设置)属性里,要用的时候就取出来,再设置src属性就可以了,而src一开始则放入占位图显示(占位图用本地工程下的一张图片即可)。

条件

==- 存在真实路径的key值,如上面所述的‘data-original’,并且为img标签元素==

==- 该img为显示元素,没有隐藏==

==- 该img在浏览器的可视范围区域内==

==- 该img是否在下载操作的缓存数组里面==

3、热身几个关键点的基础知识。

屏幕可视窗口大小
javas jQuery
window.screen.availHeight $(window).height()
浏览器窗口顶部与文档顶部之间的距离,也就是滚动条滚动的距离
javas jQuery
document.body.scrollTop $(document).scrollTop()
元素相对于文档document顶部、左边的距离
jQuery
元素距离文档顶的距离
$(o).offset().top   
元素距离文档左边缘的距离
$(o).offset().left
JavaScript
function getPosition (obj) {
        var pos = {
            top:0,
            left:0
        };
        while (obj.offsetParent) {
            pos.top += obj.offsetTop+obj.clientTop;
            pos.left += obj.offsetLeft+obj.clientLeft;
            obj = obj.offsetParent;
        }
        return pos;
    }
image

4、如何判断某个元素进入或者即将进入可视窗口区域?

image
image

关键代码如下

        var a = offsetTop(img);
if (a > document.body.scrollTop && a < (document.body.scrollTop + window.screen.availHeight)) {
     // 在可视范围内
}

三、ytLazyLoad.js

ytLazyLoad.js jquery.lazyload.min.js
纯JavaScript操作,不依赖任何的js文件 jquery操作,依赖于jquery.min.jsw文件
图片加载成功或失败有回调事件 成功或者失败不存在回调事件
只支持垂直滑动 支持垂直、水平滑动
只支持一级窗口嵌套 支持多个窗口嵌套

码云公开代码的地址:
http://git.oschina.net/freedom_coco/codes/xy7ocuz8i4qajfknvpb2g12

使用方法:

YTImageLazyLoad({
        success: function(obj, index) {
            console.log(obj + '加载成功,下标为' + index);
        },
        failure: function(obj, index) {
            console.log(obj + '加载失败,下标为' + index);
        },
        cusImgclass: 'imgURL quotepic userHead',
        cusImgid: 'xx xxx xxx'
    });
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,203评论 1 92
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,711评论 19 139
  • 转载请声明 原文链接地址 关注公众号获取更多资讯 第一部分 HTML 第一章 职业规划和前景 职业方向规划定位...
    前端进阶之旅阅读 16,920评论 32 459
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 179,356评论 25 708
  • 在生活中,当我们刚走出校门,孑然一身时,我们随时都在为以下至少一件事情焦虑着: 担心找不着好工作;担心找不着情意相...
    明逸随想录阅读 766评论 0 3

友情链接更多精彩内容