zoukankan      html  css  js  c++  java
  • 移动端图片延迟加载

    由于国内的电信网络性价比的限制,和手机处理能力的差异,在设计一个无线应用的时候,

    为用户节省流量是一个非常重要的考虑因素。可以说每一个字节都应该为客户端节省。

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

    一、使用缓存 比如 利用浏览器本地存储 前面已经讨论过

    二、延迟加载代码 (触底检测,通过接口获取数据)

    三、资源的延迟加载,图片出现在可视区域再加载,(不考虑自动播放的情况下)音频视频按用户点击加载。

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

    例子基于jQuery 和 jQuery mobile 

    原理:用户滑动屏幕,屏幕滚动结束(用jQuery 提供的 window scrollstop 事件合适 ) 检测出现在viewport中的图片。

    替换图片的 真正 src 属性即可。

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

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

    主要代码:

    var refreshTimer = null,
    	mebook = mebook || {};
    
    /*
    *滚动结束 屏幕静止一秒后检测哪些图片出现在viewport中
    *和PC端不同 由于无线速度限制 和手机运算能力的差异 1秒钟的延迟对手机端的用户来说可以忍受
    */
    $(window).on('scrollstop', function () {
    	if (refreshTimer) {
    		clearTimeout(refreshTimer);
    		refreshTimer = null;
    	}
    	refreshTimer = setTimeout(refreshAll, 1e3);
    });
    	
    	
    $.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)
    };
    
    mebook.getInViewportList = function () {
        var list = $('#bookList li'),
            ret = [];
        list.each(function (i) {
            var li = list.eq(i);
            if ($.inViewport(li)) {
                mebook.loadImg(li);
            }
        });
    };
    
    mebook.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');
            });
        }
    };
    

    应用实例 

    手机扫描二维码:

    二维码

     

  • 相关阅读:
    springboot使用war包部署到外部tomcat
    html只允许输入的数据校验,只允许输入字母汉字数字等
    转:执行ajax加载页面中的js
    php 解析xml 的四种方法(转)
    Php 获取xml中的节点值
    php中DOMDocument简单用法(XML创建、添加、删除、修改)
    PHP对XML文件操作详细
    转载 PHP 程序员学数据结构与算法之《栈》
    php读取二进制流(C语言结构体struct数据文件)的深入解析
    关于php和C语言接口的结构传递问题,udp,tcp通信
  • 原文地址:https://www.cnblogs.com/trance/p/3118984.html
Copyright © 2011-2022 走看看