一段實現頁面上的圖片延時載入的js

來源:互聯網
上載者:User

標籤:c   a   get   com   strong   使用   

大家如果使用firebug去查看的話就會發現,當你滾動到相應的行時,當前行的圖片才即時載入的,這樣子的話頁面在開啟只加可視地區的圖片,而其它隱藏的圖片則不載入,一定程式上加快了頁面載入的速度,對於比較長的頁面來說,這個方案是比較好的。

 

實現原理 

把所有需要延時載入的圖片改成如下的格式:

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.