欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于javascript實(shí)現(xiàn)圖片懶加載

 更新時(shí)間:2016年01月05日 15:59:22   投稿:lijiao  
這篇文章主要介紹了javascript實(shí)現(xiàn)圖片懶加載的方法及思路,有時(shí)我們需要用懶加載,也就是延遲加載圖片的方式,來(lái)提高網(wǎng)站的親和力,需要的朋友可以參考下

一、定義

  圖片延遲加載也稱為懶加載,延遲加載圖片或符合某些條件時(shí)才加載某些圖片,通常用于圖片比較多的網(wǎng)頁(yè)??梢詼p少請(qǐng)求數(shù)或者延遲請(qǐng)求數(shù),優(yōu)化性能。

 二、呈現(xiàn)形式

【1】延時(shí)加載,使用setTimeout或setInterval進(jìn)行加載延遲,如果用戶在加載前就離開,自然就不會(huì)進(jìn)行加載。
【2】條件加載,符合某些條件或者觸發(fā)了某些條件才開始異步加載。
【3】可視區(qū)域加載,僅僅加載用戶可以看到的區(qū)域,這個(gè)主要監(jiān)控滾動(dòng)條來(lái)實(shí)現(xiàn),一般距離用戶看到的底邊很近的時(shí)候開始加載,這樣能保證用戶下拉時(shí)圖片正好接上,不會(huì)有太長(zhǎng)時(shí)間的停頓。

 三、基本步驟

【1】網(wǎng)頁(yè)中的圖片都設(shè)為同一張圖片
【2】給圖片增加data-original = "img/test.jpg"的屬性,保存圖片的真實(shí)地址
【3】當(dāng)觸發(fā)某些條件時(shí),自動(dòng)改變?cè)搮^(qū)域的圖片的src屬性為真實(shí)的地址 

四、應(yīng)用

1、點(diǎn)擊按鈕顯示圖片

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
body{
  margin: 0;
}
img{
  height: 100px;
  width: 100px;
}
</style>
</head>
<body>
<button>加載圖片</button>
<img src="#" alt="測(cè)試" data-original = "img/test.png">
<script>
var oBtn = document.getElementsByTagName('button')[0];
var oImg = document.images[0];  
oBtn.onclick = function(){
  oImg.src = "img/loading.gif";
  if(oImg.dataset){
    aftLoadImg(oImg,oImg.dataset.original);  
  }else{
    aftLoadImg(oImg,oImg.getAttribute("data-original"));
  }
}
function aftLoadImg(obj,url){
  var oImg = new Image();
  oImg.onload = function(){
    obj.src = oImg.src;
  }
  oImg.src = url;
}
</script>  
</body>
</html>


2、可視區(qū)顯示圖片

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
body{
  margin: 0;
}
ul{
  margin: 0;
  padding: 0;
  list-style: none;
}
img{
  border: none;
  vertical-align: middle;
}
.in{
  border: 1px solid black;
  margin: 10px;
  text-align: center;
  height: 400px;
  width: 400px;
  float: left;
}
.in img{
  height: 400px;
  width: 400px;
}
</style>
</head>
<body>
<ul class="list">
  <li class="in"><img src="img/loading.gif" alt="測(cè)試" data-original = "img/img1.gif"></li>
  <li class="in"><img src="img/loading.gif" alt="測(cè)試" data-original = "img/img2.gif"></li>
  <li class="in"><img src="img/loading.gif" alt="測(cè)試" data-original = "img/img3.gif"></li>
  <li class="in"><img src="img/loading.gif" alt="測(cè)試" data-original = "img/img4.gif"></li>  
  <li class="in"><img src="img/loading.gif" alt="測(cè)試" data-original = "img/img1.gif"></li>
  <li class="in"><img src="img/loading.gif" alt="測(cè)試" data-original = "img/img2.gif"></li>
  <li class="in"><img src="img/loading.gif" alt="測(cè)試" data-original = "img/img3.gif"></li>
  <li class="in"><img src="img/loading.gif" alt="測(cè)試" data-original = "img/img4.gif"></li>              
</ul>

<script>
var oBtn = document.getElementsByTagName('button')[0];
var aImages = document.images;
loadImg(aImages);
window.onscroll = function(){
  loadImg(aImages);
};
function loadImg(arr){
  for( var i = 0,len = arr.length; i < len; i++){
    if(arr[i].getBoundingClientRect().top < document.documentElement.clientHeight && !arr[i].isLoad){
      arr[i].isLoad = true;
      arr[i].style.cssText = "transition: ''; opacity: 0;"
      if(arr[i].dataset){
        aftLoadImg(arr[i],arr[i].dataset.original);  
      }else{
        aftLoadImg(arr[i],arr[i].getAttribute("data-original"));
      }
      (function(i){
        setTimeout(function(){
          arr[i].style.cssText = "transition: 1s; opacity: 1;"
        },16)
      })(i);
    }
  }
}
function aftLoadImg(obj,url){
  var oImg = new Image();
  oImg.onload = function(){
    obj.src = oImg.src;
  }
  oImg.src = url;
}

</script>  
</body>
</html>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,順利實(shí)現(xiàn)javascript圖片懶加載。

相關(guān)文章

最新評(píng)論