手机网站移动端图片实现延迟加载

由于国内的电信网络性价比的限制,和手机处理能力的差异,在设计一个无线应用的时候,为用户节省流量是一个非常重要的考虑因素。可以说每一个字节都应该为客户端节省。

节约流量可以从以下几个方面关注:

一、使用缓存 比如 利用浏览器本地存储 前面已经讨论过
二、延迟加载代码 (触底检测,通过接口获取数据)
三、资源的延迟加载,图片出现在可视区域再加载,(不考虑自动播放的情况下)音频视频按用户点击加载。

今天简单说一下图片延迟加载的实现方式。

例子基于 jQuery 和 jQuery mobile

原理:用户滑动屏幕,屏幕滚动结束(用 jQuery mobile 提供的 window scrollstop 事件合适 ) 检测出现在 viewport 中的图片。
替换图片的真正 src 属性即可。

技巧:滚动结束之后不要立即检测加载,设置一秒延时,也许用户会立即开始下一次滚屏,基于现在的网络环境,1秒的延时可以说明用户真正想查看这些内容。用微信的朋友可以仔细体验一下这一点。

由于有时钟的控制,当用户频繁快速翻动屏幕,不会发大量请求。

var lazyload = lazyload || {};

$.belowthefold = function(element) {
    var fold = $(window).height() + $(window).scrollTop();
    return fold <= $(element).offset().top
},
$.abovethetop = function(element) {
    var top = $(window).scrollTop();
    return top >= $(element).offset().top + $(element).height()
},

// 判断元素是否出现在viewport中 依赖于上两个扩展方法
$.inViewport = function(element) {
    return ! $.belowthefold(element) && !$.abovethetop(element)
},
lazyload.getInViewportList = function() {
    var list = $("#bookList li");
    return list.each(function(i) {
        var li = list.eq(i);
        $.inViewport(li) && lazyload.loadImg(li)
    })
},
lazyload.loadImg = function(li) {
    if (li.find("img[_src]").length) {
        var img = li.find("img[_src]"),
            src = img.attr("_src");
        img.attr("src", src).load(function() {
            img.removeAttr("_src")
        })
    }
},
$(function() {
    var refreshTimer = null;

    // 滚动结束 屏幕静止一秒后检测哪些图片出现在viewport中
    // 和PC端不同 由于无线速度限制 和手机运算能力的差异 1秒钟的延迟对手机端的用户来说可以忍受
    $(window).on("scrollstop", function() {
        refreshTimer && (clearTimeout(refreshTimer), refreshTimer = null),
        refreshTimer = setTimeout(lazyload.getInViewportList, 1e3)
    })
});

[手机网站移动端图片实现延迟加载[续]] http://varyu.com/notes/130.html
[原文] http://www.cnblogs.com/trance/archive/2013/06/05/3118984.html
[Demo] http://zsall.mobilem.360.cn/html/ebook/mbook.html

发表评论
* 昵称
* Email
* 网址
* 评论