要想缩短首屏加载时间,思路通常是减小http请求次数和下降每次的请求量。本文中使用现成的lazyload.js插件,文末会放出下载地址。html
lazyload.js能够实现图片分批次加载,不是一次性加载完毕再分批次展示。使用该插件有个注意的地方,图片要加上宽高。由于默认图是1像素的,因此若是没有给图片限制宽高,当滚动条滚动时会所有加载出来。jquery
好比下面这段代码,其中的图片会一次性加载完成。浏览器
<img data-original="images/bg00001.jpg" src="/js/grey.gif" border="0" /> <img data-original="images/bg00002.jpg" src="/js/grey.gif" border="0" /> <img data-original="images/bg00003.jpg" src="/js/grey.gif" border="0" /> <img data-original="images/bg00004.jpg" src="/js/grey.gif" border="0" />
若是加上宽高限制,则每次只会展现可见区域的图片。具体显示多少张,是根据窗口高度和图片高度而定。服务器
<img data-original="images/bg00001.jpg" height="600" src="/js/grey.gif" border="0" /> <img data-original="images/bg00002.jpg" height="600" src="/js/grey.gif" border="0" /> <img data-original="images/bg00003.jpg" height="600" src="/js/grey.gif" border="0" /> <img data-original="images/bg00004.jpg" height="600" src="/js/grey.gif" border="0" />
从以上代码能够看出,须要延迟加载的图片须要使用data-original属性,属性值是真实的图片地址,默认的src值使用1像素的图片(grey.gif)ide
使用时须要先加载jqury.js,再加载lazyload.js,而且须要写一段js代码,具体代码以下测试
<script src="js/jquery-1.7.js"></script> <script src="js/jquery.lazyload.js" ></script> <script> $(function() { $("img").lazyload({ effect : "fadeIn" }); }); </script>
lazyload参数使用说明
一、用图片提早占位
placeholder : "img/grey.gif",
参数:placeholder,值为某一图片路径.此图片用来占据将要加载的图片的位置,待图片加载时,占位图则会隐藏
二、载入使用何种效果
effect : "fadeIn",
参数:effect(特效),值有show(直接显示),fadeIn(淡入),slideDown(下拉)等,经常使用fadeIn
三、提早开始加载
threshold : 200,
参数:threshold,值为数字,表明页面高度.如设置为200,表示滚动条在离目标位置还有200的高度时就开始加载图片,能够作到不让用户察觉.
四、事件触发时才加载
event : "click",
参数:event,值有click(点击),mouseover(鼠标划过),sporty(运动的),foobar(…).能够实现鼠标莫过或点击图片才开始加载,后两个值未测试…
五、对某容器中的图片实现效果
container: $("#container"),
参数:container,值为某容器.lazyload默认在拉动浏览器滚动条时生效,这个参数可让你在拉动某DIV的滚动条时依次加载其中的图片
六、图片排序混乱时
failurelimit : 10,
参数:failurelimit,值为数字.lazyload默认在找到第一张不在可见区域里的图片时则再也不继续加载,但当HTML容器混乱的时候可能出现可见区域内图片并没加载出来的状况,failurelimit意在加载N张可见区域外的图片,以免出现这个问题
这些都是在html中的<img>图片延迟加载,其实背景图片也能够延迟加载。背景图片图片延迟加载有一个更大的好处是,爬虫爬取时没法爬取到图片,节省了服务器资源。
背景图片延迟加载跟html中图片延迟加载很类似ui
<div class="lazy" data-original="img/example.jpg" width="640" height="480"></div>
这样,只有当这个div出如今可视视窗内时,背景图才会加载显示。spa