文档章节

js实现网页图片延时加载(加载可见区域)的原理和代码 提高网站打开速度

daniel-john
 daniel-john
发布于 2014/06/21 22:32
字数 1373
阅读 2081
收藏 42
点赞 0
评论 0

有时我们看到一些大型网站,页面如果有很多图片的时候,当你滚动到相应的行时,当前行的图片才即时加载的,这样子的话页面在打开只加可视区域的图片,而其它隐藏的图片则不加载,一定程序上加快了页面加载的速度,对于比较长的页面来说,这个方案是比较好的。

推荐:使用jquery图片延迟加载插件jquery.lazyload实现图片延迟


实现原理:

把所有需要延时加载的图片改成如下的格式:

<img lazy_src="图片路径" border="0"/>

然后在页面加载时,把所有使用了lazy_src的图片都保存到数组里,然后在滚动时计算可视区域的top,然后把延时加载的图片中top小于当前可视区域(即图片出现在可视区域内)的图片的src的值用lazy_src的来替换(加载图片):

JS代码:

lazyLoad
 = (function()
 {  
    var map_element
 = {};
  
    var element_obj
 = [];
  
    var download_count
 = 0;
  
    var last_offset
 = -1;
  
    var doc_body;
  
    var doc_element;
  
    var lazy_load_tag;
  
    function initVar(tags)
 {
  
        doc_body
 = document.body;
  
        doc_element
 = document.compatMode == 'BackCompat' ?
 doc_body : document.documentElement;
  
        lazy_load_tag
 = tags || ["img", "iframe"];
  
    };
  
    function initElementMap()
 {
  
        var all_element
 = [];
  
        //从所有相关元素中找出需要延时加载的元素
  
        for (var i
 = 0,
  
len
 = lazy_load_tag.length; i < len; i++) {
  
            var el
 = document.getElementsByTagName(lazy_load_tag[i]);
  
            for (var j
 = 0,
  
len2
 = el.length; j < len2; j++) {
  
                if (typeof (el[j])
 == "object" &&
 el[j].getAttribute("lazy_src"))
 {
  
                    element_obj.push(all_element[key]);
  
                }
  
            }
  
        }
  
   
  
        for (var i
 = 0,
  
len
 = element_obj.length; i < len; i++) {
  
            var o_img
 = element_obj[i];
  
            var t_index
 = getAbsoluteTop(o_img); //得到图片相对document的距上距离
  
            if (map_element[t_index])
 {
  
                map_element[t_index].push(i);
  
            } else {
  
                //按距上距离保存一个队列
  
                var t_array
 = [];
  
                t_array[0]
 = i;
  
                map_element[t_index]
 = t_array;
  
                download_count++; //需要延时加载的图片数量
  
            }
  
        }
  
   
  
    };
  
    function initDownloadListen()
 {
  
        if (!download_count) return;
  
        var offset
 = (window.MessageEvent && !document.getBoxObjectFor) ? doc_body.scrollTop : doc_element.scrollTop;
  
        //可视化区域的offtset=document的高+
  
        var visio_offset
 = offset + doc_element.clientHeight;
  
        if (last_offset
 == visio_offset) {
  
            setTimeout(initDownloadListen,
 200);
  
            return;
  
        }
  
        last_offset
 = visio_offset;
  
        var visio_height
 = doc_element.clientHeight;
  
        var img_show_height
 = visio_height + offset;
  
        for (var key in map_element)
 {
  
            if (img_show_height
 > key) {
  
                var t_o
 = map_element[key];
  
                var img_vl
 = t_o.length;
  
                for (var l
 = 0; l < img_vl; l++) {
  
                    element_obj[t_o[l]].src
 = element_obj[t_o[l]].getAttribute("lazy_src");
  
                }
  
                delete map_element[key];
  
                download_count--;
  
            }
  
        }
  
        setTimeout(initDownloadListen,
 200);
  
    };
  
    function getAbsoluteTop(element)
 {
  
        if (arguments.length
 != 1 || element == null)
 {
  
            return null;
  
        }
  
        var offsetTop
 = element.offsetTop;
  
        while (element
 = element.offsetParent) {
  
            offsetTop
 += element.offsetTop;
  
        }
  
        return offsetTop;
  
    }
  
    function init(tags)
 {
  
        initVar(tags);
  
        initElementMap();
  
        initDownloadListen();
  
    };
  
    return {
  
        init:
 init
  
    }
  
})();

使用方法:把页面上需要延时加载的图片src改成为lazy_src,然后把上面的js放到body最后面,然后调用:lazyLoad.init();
调戏的方法可以使用firebug来查看一时图片是否是延时加载。
另外:
如果你的页面上存在有内容切换的栏目的话,可能在切换时切换的内容里的图片可能会不显示,处理的方法是在内容时单独图片加载处理,如:

///切换内容的代码…
  
 chlid.find("img[init_src]").each(function(){
  
    $(this).attr("src",$(this).attr("init_src"));
  
    $(this).removeAttr("init_src");
  
 });

所谓图片异步加载,意思是不用一次把图片全部加载完,你可以叫它延迟加载,缓冲加载都行。

  看看你有没有这种需求:某篇文章图片很多,如果在载入文章时就载入所有图片,无疑会延缓载入速度,让用户等更久,所以,我想找这样一种插件,让网页只加载 浏览器视野范围内的图片,没出现在范围内的图片就暂不加载,等用户滑动滚动条时再逐步加载。lazyload就是用来实现这种效果。
lazyload.js其实是jQuery的一个插件,全称是jquery.lazyload.js,看它的名字就知道它的作用了——就是偷懒载入的意思。由于它是javascript写的,所以适用于所有网页,包括Wordpress。

  想要使用lazyload,得先载入jQuery,它是依靠jQuery来实现效果的。至于jQuery,大家不用去下载了,可以直接连接存放在Google服务器上的jQuery文件,永远不用担心丢失(当然,如果有天朝完全屏蔽Google的那一天的话……)


特效优点:

  加速wordpress站点的页面载入速度;

  不唐突的图片渐显方式;

  代码精简,便于操作维护,JS代码仅仅 1.6KB  先决条件是:你的站加载了 Jquery.js

原理:

  这个特效是少有的即华丽又加速的效果,因为它能判断访客是不是在查看当前图片,若非则加载预留的填充图片 grey.gif ,等到访客滑动鼠标滑轮或浏览到图片位置时,真正的图片地址才会加载。

   也就是说,如果访客瞬间打开你的页面,然后瞬间关闭,处于页脚的图片是不被加载的,何乐而不为呢?

   不用担心对访客的友好程度,这个效果会在图片即将被浏览到的时候就开始加载图片;

实现方法:

下载 jquery.lazyload.js

下载 预填充图片 fill.gif


  将上面2文件,放到您的网站的某个目录,或者你直接在外站调用。

    在当前主题的 header.php 中适当位置添加下面 JS调用代码,我当期用的inove主题后台就有添加js代码的地方:

【部分请自定义】

 【$("img")部分可以限定对页面中的哪些img生效】比如修改成$(".content img")

   压缩包中除了lazyload.js外,还有一个grey.gif图片文件。这个图片的作用是,当页面上图片未载入时,就显示这张图片。将JS文件与图片传到你的空间,然后在你主题的header.php文件中加入


本文转载自:http://blog.csdn.net/yafei450225664/article/details/23462699

共有 人打赏支持
daniel-john
粉丝 17
博文 132
码字总数 56017
作品 0
其他
程序员
DEDE让广告延时加载显示,大大提高网页访问的速度

延迟默认的第一个广告(aid=1)为例。 1、在你要放置广告的地方加入以下代码,中间的文字可以修改成自己的词语、代码或者图像等。 <span id="topbanner">精彩内容读取中……</span> 2、在</b...

Deacyn
2014/03/04
0
0
Lazy Load, 延迟加载图片的 jQuery 插件

Lazy Load 是一个用 JavaScript 编写的 jQuery 插件. 它可以延迟加载长页面中的图片. 在浏览器可视区域外的图片不会被载入, 直到用户将页面滚动到它们所在的位置. 这与图片预加载的处理方式正...

xiaoxin
2014/07/09
0
0
网站性能工具Yslow的使用方法

Yslow是雅虎开发的基于网页性能分析浏览器插件,从年初我使用了YSlow后,改变了博客模板大量冗余代码,不仅提升了网页的打开速度,这款插件还帮助我分析了不少其他网站的代码,之前我还特意写...

LorinLuo
2015/03/11
0
0
10个技巧助您提高网站访问速度

1、如果可能的话,延迟加载一些内容 可以使用Ajax来按需加载部分内容。比如一个相册,可以在用户浏览页面时先出缩略图,当用户点击了,然后异步请求原图并展示,这样用户如果只需要看几张图片...

lovedreamland
2011/02/24
0
0
精简代码,为网站减负的十大建议

2013年,网页文件大小增加了32%,竟然达到了1.7Mb,包含96个独立HTTP请求。这只是一个平均数值,其中近一半的网站已经超过了这个数值。网站的过度臃肿正趋于流行,其中很大的责任在于Web开发...

勤奋的码农
2014/01/27
0
0
为Web应用程序提速的50条秘技

快速响应网络请求。 避免重定向。排名前1000的网站中,63%使用了重定向。如果不执行重定向的话,页面速度可以提高10%。 避免Meta-refresh。世界上14%的URL使用了Meta-refresh。 尽可能通过C...

knots
2012/12/12
0
2
精简代码,为网站减负的十大建议

2013年,网页文件大小增加了32%,竟然达到了1.7Mb,包含96个独立HTTP请求。这只是一个平均数值,其中近一半的网站已经超过了这个数值。网站的过度臃肿正趋于流行,其中很大的责任在于Web开发...

樱花泪
2014/01/27
0
2
小技巧给网页减肥 让网站访问提速

http://www.sina.com.cn 2009年07月23日 14:39 IT168.com 【IT168 论坛采风】对于网站设计师来讲,网站的访问速度甚至比内容还重要。就算网站内容很优秀,但如果访问速度很慢,相信也不会有多...

晨曦之光
2012/03/09
0
0
利用CSS、JavaScript及Ajax实现图片预加载的三大方法

摘要:图片的加载速度往往影响着网站整体的用户体验,尤其对于包含大量图片的网站。对图片进行预加载,不失为一个高效的解决方案。如何实现预加载?本文将例举利用CSS、JavaScript及Ajax实现...

spademan
2013/10/22
0
0
www.beishuo.net 网站打开异常慢的原因

现象:客户投诉http://www.beishuo.net/ 网站在移动线路下打不开或者打开异常缓慢(墨绿色是服务器向客户端发送数据的时间,显得非常耗时) 分析:这个CASE比较有意思,我在用科来分析数据包...

normanhere
06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

CVE-2013-0077 堆溢出分析

找了很久才发现这个环境比较容易搭建分析... 环境: 系统---Win XP SP3 漏洞程序:QQPlayer 3.7.892.400 出错DLL:quartz.dll 6.5.2600.5512 调试工具:x32db+gflag.exe 过程: 首先gflag设置...

Explorer0
16分钟前
5
0
python上传文件

//注意 <form action="/login/" method="post" enctype="multipart/form-data"> f=request.FILES.get('fafa') ff=open(f.name,mode='wb') for i in f.chunks(): ff.write(i) ff.close()......

南桥北木
29分钟前
0
0
CISCO VPN Client Reason 442 WIN8/10错误解决方案

http://jdkleo.iteye.com/blog/2163493 引用 http://my.oschina.net/cloudcoder/blog/220391?p={{currentPage 1}} 在使用cisco VPN 客户端登录时,产生Reason 442:Failedto enable Virtual......

chenfj_fer
32分钟前
0
0
信号量有没有容量限制?

之前一直误以为信号量初始化的时候那个初始化的值是信号量的“容量”,昨天同事指出了我的错误,最初我是不相信的,经过以下代码实践,证明了我的错误: Java版: import java.util.concurr...

锟斤拷烫烫烫
36分钟前
0
0
【RocketMQ】Message存储笔记

概述 消息中间件存储分为三种,一是保存在内存中,速度快但会因为系统宕机等因素造成消息丢失;二是保存在内存中,同时定时将消息写入DB中,好处是持久化消息,如何读写DB是MQ的瓶颈;三是内...

SaintTinyBoy
47分钟前
0
0
Android应用Context详解及源码解析

Android应用Context详解及源码解析 本文定位:优质文章收集 本文转载 1 背景 今天突然想起之前在上家公司(做TV与BOX盒子)时有好几个人问过我关于Android的Context到底是啥的问题,所以就马...

lichuangnk
今天
0
0
PostgreSQL的昨天今天和明天

PostgreSQL 是一种非常复杂的对象-关系型数据库管理系统(ORDBMS), 也是目前功能最强大,特性最丰富和最复杂的自由软件数据库系统。有些特性甚至连商业数据库都不具备。 这个起源于伯克利(...

闻术苑
今天
1
0
Mysql对自增主键ID进行重新排序

1,删除原有主键: ALTER TABLE `table_name` DROP `id`; 2,添加新主键字段: ALTER TABLE `table_name` ADD `id` MEDIUMINT( 8 ) NOT NULL FIRST; 3,设置新主键: ALTER TABLE `table_nam......

niithub
今天
0
0
福利篇:免费csdn vip账号分享

分享一个发布免费csdn vip账号的网站:啰嗦vip www.lostvip.com , 各种软件开发类的视频教程:慕课网、动脑学院、黑马各大培训机构VIP视频教程,非常不错!

在水一方发盐人
今天
1
0
Nginx+Tomcat搭建高性能负载均衡集群

一、 工具   nginx-1.8.0   apache-tomcat-6.0.33 二、 目标   实现高性能负载均衡的Tomcat集群:    三、 步骤   1、首先下载Nginx,要下载稳定版:      2、然后解压两个Tom...

码代码的小司机
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部