有時我們看到一些大型網站,頁面如果有很多圖片的時候,當你滾動到相應的行時,當前行的圖片才即時載入的,這樣子的話頁面在開啟只加可視地區的圖片,而其它隱藏的圖片則不載入,一定程式上加快了頁面載入的速度,對於比較長的頁面來說,這個方案是比較好的。
推薦:使用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"); });