网页图片延时加载的js代码

时间:2024-04-22 13:22:41 

实现原理 

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

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

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

代码

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");

});

标签:图片,延时加载
0
投稿

猜你喜欢

  • 最简单的tab切换实例代码

    2023-08-22 08:38:59
  • 支持多类型数据库的c#数据库模型示例

    2024-01-13 16:41:15
  • Python实现删除重复视频文件的方法详解

    2022-06-16 03:24:29
  • JavaScript设计模式之享元模式实例详解

    2024-04-17 10:08:34
  • asp 类型转换函数大全第1/2页

    2011-04-07 11:06:00
  • Python内置函数—vars的具体使用方法

    2021-05-07 04:09:57
  • 利用Python批量导出mysql数据库表结构的操作实例

    2024-01-21 00:41:58
  • Vue中添加手机验证码组件功能操作方法

    2023-07-02 16:57:16
  • PHP中的闭包function() use() {}使用场景和技巧

    2023-06-09 21:54:07
  • 用 jQuery 來做图片伪浮水印

    2010-08-09 12:42:00
  • 详解Mysql主从同步配置实战

    2024-01-14 16:36:13
  • 基于 Python 实践感知器分类算法

    2022-08-08 05:49:31
  • 利用tkinter改变下拉列表(Combobox)的选项值

    2023-07-20 03:10:37
  • 详解python函数的闭包问题(内部函数与外部函数详述)

    2023-01-22 20:53:01
  • 一些实用性较高的js方法

    2024-04-29 13:37:40
  • Python实现深度遍历和广度遍历的方法

    2023-10-13 20:41:13
  • python版飞机大战代码分享

    2023-11-13 22:29:03
  • CREATE FUNCTION sqlserver用户定义函数

    2012-08-21 10:57:42
  • python-docx 页面设置详解

    2021-12-06 03:42:02
  • python中split方法用法分析

    2022-05-24 23:34:51
  • asp之家 网络编程 m.aspxhome.com