当前位置:   article > 正文

网站首页的图片延迟加载是怎么实现的?

图片延迟加载

随着页面信息越来越丰富饱满,尤其像淘宝,京东之类的购物网站,首页就是他们的生命线!

最近在做某银行的网站,只有挤上首页才能得到更多的关注,于是乎各种业务人员就开始了首页位置之争,为了平息他们的战乱。首页囊括了他们全部的需求,他们满意的走人了,结果技术经理来了,说首页加载怎么这么大,于是乎,减!!!

首当其冲,缩小图片K数,不够,那怎么办,好吧,进入正题。长页面未显示的部分可以先不加载,省流量就是省钱,开搞!!!

思路就是,判断图片在页面中的位置,如果图片的位置大于小于当前的屏幕高度,那么显示图片,否则隐藏图片。

怎么一开始隐藏图片呢,很简单,<img csii_src="1.png" alt="图片延迟加载实现原理">,给一个浏览器不认识的属性csii_src,当需要显示图片的时候在element.src=element.getAttribute("csii_src");,思路很简单吧,上代码了。

  1. function lazyLoad() {
  2. var map_element = {};
  3. var element_obj = [];
  4. var download_count = 0;
  5. var last_offset = -1;
  6. var doc_body = null;
  7. var doc_element = null;
  8. var lazy_load_tag = [];
  9. function initVar(tags) {
  10. doc_body = document.body;
  11. doc_element = document.compatMode == 'BackCompat' ? doc_body: document.documentElement;
  12. lazy_load_tag = tags || ["img", "iframe"];
  13. };
  14. function initElementMap() {
  15. for (var i = 0,
  16. len = lazy_load_tag.length; i < len; i++) {
  17. var el = document.getElementsByTagName(lazy_load_tag[i]);
  18. for (var j = 0,
  19. len2 = el.length; j < len2; j++) {
  20. if (typeof(el[j]) == "object" && el[j].getAttribute("csii_src")) {
  21. element_obj.push(el[j]);
  22. }//欢迎加入全栈开发交流圈一起学习交流:1007317281
  23. }
  24. }
  25. for (var i = 0,
  26. len = element_obj.length; i < len; i++) {
  27. var o_img = element_obj[i];
  28. var t_index = getAbsoluteTop(o_img);
  29. if (map_element[t_index]) {
  30. map_element[t_index].push(i);
  31. } else {
  32. var t_array = [];
  33. t_array[0] = i;
  34. map_element[t_index] = t_array;
  35. download_count++;
  36. }//欢迎加入全栈开发交流圈一起学习交流:1007317281
  37. }
  38. };
  39. function initDownloadListen() {
  40. if (!download_count) return;
  41. /*var offset = (window.MessageEvent && !document.getBoxObjectFor) ? doc_body.scrollTop
  42. : doc_element.scrollTop;*/
  43. var offset;
  44. if (os.firefox) {
  45. offset = doc_element.scrollTop;
  46. } else {
  47. offset = doc_body.scrollTop;
  48. }
  49. var visio_offset = offset + doc_element.clientHeight;
  50. if (last_offset == visio_offset) {
  51. // setTimeout(initDownloadListen, 200);
  52. return;
  53. }
  54. last_offset = visio_offset;
  55. var visio_height = doc_element.clientHeight;
  56. var img_show_height = visio_height + offset + 20;
  57. for (var key in map_element) {
  58. if (img_show_height > key) {
  59. var t_o = map_element[key];
  60. var img_vl = t_o.length;
  61. for (var l = 0; l < img_vl; l++) {
  62. element_obj[t_o[l]].src = element_obj[t_o[l]].getAttribute("csii_src");
  63. }
  64. delete map_element[key];
  65. download_count--;
  66. }
  67. }
  68. // setTimeout(initDownloadListen, 200);
  69. };
  70. function getAbsoluteTop(element) {
  71. if (arguments.length != 1 || element == null) {
  72. return null;
  73. }
  74. var offsetTop = element.offsetTop;
  75. while (element = element.offsetParent) {
  76. offsetTop += element.offsetTop;
  77. }
  78. return offsetTop;
  79. }//欢迎加入全栈开发交流圈一起学习交流:1007317281
  80. function init(tags) {
  81. initVar(tags);
  82. initElementMap();
  83. initDownloadListen();
  84. $(window).scroll(function() {
  85. initDownloadListen();
  86. });
  87. };
  88. init();
  89. }

结语

感谢您的观看,如有不足之处,欢迎批评指正。
**获取资料

转载于:https://blog.51cto.com/14145734/2387238

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/120883
推荐阅读
相关标签
  

闽ICP备14008679号