【jQuery】利用lazyload.js延迟加载技术应对多图杀猫的单一页面

有时候不可避免地在某一页面摆上大量图片,众所周知,一张网页如果上面的元素超过100KB,那么,你的网页会加载得很慢,纵使现在的网络已经不是当年的猫,然而,你也应该尽可能地提高你的网页加载速度。对于多图杀猫的单一页面可以利用到lazyload.js延迟加载技术,也可以直译为懒加载。

如下图,比如我这个页面是一个以图片为主的网站,就是要在上面同时摆上下面的15张大图。

【jQuery】利用lazyload.js延迟加载技术应对多图杀猫的单一页面_第1张图片

即使你摆个缩略图上去也会占用不少的带宽。

如下图,浏览器一次性地将15张图片加载显然不是我们想要的效果。

【jQuery】利用lazyload.js延迟加载技术应对多图杀猫的单一页面_第2张图片

此时,我们可以利用lazyload.js延迟加载技术,用户的滚动条滚到哪里,我们就将图片加载到哪里明可以看到1-15.jsp是根据滚动条的加载而加载,如果暂时加载不出来,还会有个loading.gif提前占位。


lazyload.js是一个jQuery插件,使用方法如下:

1、首先你要有1.3版本以上的jQuery,-_-!现在随随便便都是1.9,1.11的jQuery了。主要是你的网页注意引入jQuery就可以。之后可以到其官网:http://www.appelsiini.net/projects/lazyload,如下图,下载最新版的lazyload.js

【jQuery】利用lazyload.js延迟加载技术应对多图杀猫的单一页面_第3张图片

或者直接到上图右方的GitHub中下载:https://github.com/tuupola/jquery_lazyload/releases

2、下载之后将jquery_lazyload-1.9.5.zip解压,拿走里面的jquery.lazyload.min.js与jquery.scrollstop.min.js到你的站点就可以,其余都是没用的。

【jQuery】利用lazyload.js延迟加载技术应对多图杀猫的单一页面_第4张图片

3、之后就可以在网页中使用,代码如下所示,很简单。

不过你记住最最最最重要的两点,一是,所有的img,都的真实地址都写在data-original中,而不是传统的src,因为lazyload.js本身的执行机制,就是到特定的位置,才将data-original的属性值写到src。二是关于lazyload.js的脚本,尽可能放到</body>之后,否则要在脚本的前面补上$(function(){});或者window.onload=function(){},规定这段脚本在整个网页的img标签加载完毕才加载,否则是没有效果的,这个原理同《【JavaScript】出现即使设置了ID也获取不到的可能原因与window.onload》(点击打开链接)

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
        <title>Lazyload.js图片延迟加载技术</title>
        <script type="text/javascript" src="js/jquery-1.8.3.js"></script>
        <script type="text/javascript" src="js/jquery.lazyload.min.js"></script>
        <script type="text/javascript" src="js/jquery.scrollstop.min.js"></script>
    </head>
    <body>
        <img data-original="../images/1.jpg" /><br>
        <img data-original="../images/2.jpg" /><br>
        <img data-original="../images/3.jpg" /><br>
        <img data-original="../images/4.jpg" /><br>
        <img data-original="../images/5.jpg" /><br>
        <img data-original="../images/6.jpg" /><br>
        <img data-original="../images/7.jpg" /><br>
        <img data-original="../images/8.jpg" /><br>
        <img data-original="../images/9.jpg" /><br>
        <img data-original="../images/10.jpg" /><br>
        <img data-original="../images/11.jpg" /><br>
        <img data-original="../images/12.jpg" /><br>
        <img data-original="../images/13.jpg" /><br>
        <img data-original="../images/14.jpg" /><br>
        <img data-original="../images/15.jpg" /><br>
    </body>
    <script type="text/javascript">
        $("img").lazyload({
            placeholder: "../images/loading.gif",//未加载前的占位图片,一般就是一些“载入中……”的gif 
            threshold: 200,//提前200px开始加载
            event: "scrollstop",//触发加载的方式为滚动条
            effect: "fadeIn"//带淡入的动画效果
        });
    </script>
</html>

最后,讲讲这个东西的兼容性问题,据说这个东西的兼容性非常非常优秀,如下图所示:

【jQuery】利用lazyload.js延迟加载技术应对多图杀猫的单一页面_第5张图片

那些说不行的人,很可能是自己的js没有写好,比如《【JavaScript】数组定义末尾请不要留下逗号》(点击打开链接)之类的。亲测也确实如此,以下是在IE8的测试效果,还行:

【jQuery】利用lazyload.js延迟加载技术应对多图杀猫的单一页面_第6张图片

你可能感兴趣的:(jquery,图片,延迟加载,lazyload,懒加载)