微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

js实现网页图片延时加载 提升网页打开速度

提升网页加载速度的方法有很多种,用 jquery.lazyload.js 实现图片异步延迟加载,对于页面包含图片较多的网站来说,会是个不错的提升网页打开速度的方法代码君网站栏目页列表左侧,在PC端预览时能看到一个文章略缩图展示模块,一定程度上会延长网页加载时间。本文采用图片异步延迟加载的方法,来提升本站页面加载速度。

图片异步加载,就是不必一次性把页面的所有图片都加载显示出来,等用户滑动滚动条到某个位置时才会加载显示相应位置的图片,这样能很好地提升网页加载速度,进一步提升用户体验。

有很多技术性文章的配图是非常多的,如果打开网页时要求能够一次性加载完成所有图片的话,用户等候的时间肯定就得非常长了。这种做法会让用户体验非常不好,况且也没有必要一次性把页面上的所有图片都加载出来。图片异步延迟加载,才是网页设计中最合理最恰当的做法。

我们用 jquery.lazyload.js 来实现图片异步延迟加载,记得要先载入 jQuery 才行。

1、导入 JS 插件

rush:js;">

2、在页面中插入 JavaScript 代码

rush:js;"> $(document).ready(function($){ $("img").lazyload({ placeholder:"grey.gif",//加载图片前的占位图片 effect:"fadeIn" //加载图片使用的效果(淡入) }); });

通过以上两步,就能简单实现网页图片异步延时加载了。

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

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

实现原理:

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

rush:xhtml;"> 图片路径" border="0"/>

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

JS代码

rush: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; <a href="https://www.jb51.cc/tag/L/" target="_blank" class="keywords">L++</a>) {

      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) {

ini<a href="https://www.jb51.cc/tag/tvar/" target="_blank" class="keywords">tvar</a>(tags);

initElementMap();

initDownloadListen();

};

return {

init: init

}

})();

使用方法

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

rush:js;"> ///切换内容代码

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来实现效果的。

以上就是本文的全部内容,希望大家对js实现网页图片延时加载有了更深入的学习了解。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据复制操作的两种方式。‌在聊深浅拷贝之前咱得了解一下js中的两种数据类型:
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:重建二叉树、反向输出链表每个节点 题目 重建二叉树: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列 {1,2,4,7,3,5,6,8} 和中序遍历序列 {
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须了解的知识点,现在迎来了ES6+的时代,因为箭头函数的出现,所以感觉有必要对 this 问题梳理一下,所以刚好总结一下JavaScript中this指向的问题。
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高