懶加載和預(yù)加載

一棋傍、懶加載

1.什么是懶加載

懶加載也叫延遲加載亿絮,指的是在長網(wǎng)頁中延遲加載圖像壹无,是一種很好優(yōu)化網(wǎng)頁性能的方式。用戶滾動到它們之前岖是,可視區(qū)域外的圖像不會加載豺撑。這與圖像預(yù)加載相反,在長網(wǎng)頁上使用延遲加載將使網(wǎng)頁加載更快陆错。在某些情況下,它還可以幫助減少服務(wù)器負載绳慎。常適用圖片很多杏愤,頁面很長的電商網(wǎng)站場景中。

2.為什么要用懶加載

  • 能提升用戶的體驗邓了,不妨設(shè)想下骗炉,用戶打開像手機淘寶長頁面的時候,如果頁面上所有的圖片都需要加載乍丈,由于圖片數(shù)目較大,等待時間很長,用戶難免會心生抱怨宗收,這就嚴重影響用戶體驗混稽。
  • 減少無效資源的加載菲盾,這樣能明顯減少了服務(wù)器的壓力和流量,也能夠減小瀏覽器的負擔(dān)。
  • 防止并發(fā)加載的資源過多會阻塞js的加載奴璃,影響網(wǎng)站的正常使用唱星。

3.懶加載的原理

首先將頁面上的圖片的 src 屬性設(shè)為空字符串,而圖片的真實路徑則設(shè)置在data-original屬性中,
當頁面滾動的時候需要去監(jiān)聽scroll事件,在scroll事件的回調(diào)中,判斷我們的懶加載的圖片是否進入可視區(qū)域,如果圖片在可視區(qū)內(nèi)將圖片的 src 屬性設(shè)置為data-original 的值热凹,這樣就可以實現(xiàn)延遲加載。

4.懶加載實現(xiàn)步驟

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Lazyload</title>
    <style>
      .image-item {
        display: block;
        margin-bottom: 50px;
        height: 200px;//一定記得設(shè)置圖片高度
    }
    </style>
</head>
<body>
<img src="" class="image-item" lazyload="true"  data-original="images/1.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/2.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/3.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/4.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/5.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/6.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/7.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/8.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/9.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/10.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/11.png"/>
<img src="" class="image-item" lazyload="true"  data-original="images/12.png"/>
<script>
var viewHeight =document.documentElement.clientHeight//獲取可視區(qū)高度
function lazyload(){
var eles=document.querySelectorAll('img[data-original][lazyload]')
Array.prototype.forEach.call(eles,function(item,index){
var rect
if(item.dataset.original==="")
   return
rect=item.getBoundingClientRect()// 用于獲得頁面中某個元素的左泪电,上般妙,右和下分別相對瀏覽器視窗的位置
if(rect.bottom>=0 && rect.top < viewHeight){
!function(){
  var img=new Image()
  img.src=item.dataset.original
  img.onload=function(){
    item.src=img.src
    }
item.removeAttribute("data-original")//移除屬性,下次不再遍歷
item.removeAttribute("lazyload")
   }()
  }
 })
}
lazyload()//剛開始還沒滾動屏幕時相速,要先觸發(fā)一次函數(shù)碟渺,初始化首頁的頁面圖片
document.addEventListener("scroll",lazyload)
</script>
</body>
</html>

二突诬、預(yù)加載

1.什么是預(yù)加載

資源預(yù)加載是另一個性能優(yōu)化技術(shù)苫拍,我們可以使用該技術(shù)來預(yù)先告知瀏覽器某些資源可能在將來會被使用到。預(yù)加載簡單來說就是將所有所需的資源提前請求加載到本地旺隙,這樣后面在需要用到時就直接從緩存取資源绒极。

2.為什么要用預(yù)加載

在網(wǎng)頁全部加載之前,對一些主要內(nèi)容進行加載蔬捷,以提供給用戶更好的體驗垄提,減少等待的時間。否則周拐,如果一個頁面的內(nèi)容過于龐大铡俐,沒有使用預(yù)加載技術(shù)的頁面就會長時間的展現(xiàn)為一片空白,直到所有內(nèi)容加載完畢妥粟。

3.實現(xiàn)預(yù)加載的幾種辦法

  • 使用HTML標簽

<img src="http://pic26.nipic.com/20121213/6168183 0044449030002.jpg" style="display:none"/>

  • 使用Image對象

<script src="./myPreload.js"></script>

//myPreload.js文件
var image= new Image()
image.src="http://pic26.nipic.com/20121213/6168183 004444903000 2.jpg"
  • 使用XMLHttpRequest對象,雖然存在跨域問題审丘,但會精細控制預(yù)加載過程
var xmlhttprequest=new XMLHttpRequest();
xmlhttprequest.onreadystatechange=callback勾给;
xmlhttprequest.onprogress=progressCallback滩报;
xmlhttprequest.open("GET","http://image.baidu.com/mouse,jpg",true)锅知;
xmlhttprequest.send();
function callback(){
  if(xmlhttprequest.readyState==4&& xmlhttprequest.status==200){
    var responseText=xmlhttprequest.responseText露泊;
  }else{
     console.log("Request was unsuccessful:"+xmlhttprequest.status)喉镰;
  }
}
function progressCallback(e){
e=e || event;
if(e.lengthComputable){
console.log("Received"+e.loaded+"of"+e.total+"bytes")
}
}

PreloadJS提供了一種預(yù)加載內(nèi)容的一致方式惭笑,以便在HTML應(yīng)用程序中使用侣姆。預(yù)加載可以使用HTML標簽以及XHR來完成。默認情況下沉噩,PreloadJS會嘗試使用XHR加載內(nèi)容捺宗,因為它提供了對進度和完成事件的更好支持,但是由于跨域問題川蒙,使用基于標記的加載可能更好蚜厉。

//使用preload.js
var queue=new createjs.LoadQueue();//默認是xhr對象畜眨,如果是new createjs.LoadQueue(false)是指使用HTML標簽昼牛,可以跨域
queue.on("complete",handleComplete,this);
queue.loadManifest([
{id:"myImage",src:"http://pic26.nipic.com/20121213/6168183  0044449030002.jpg"},
{id:"myImage2",src:"http://pic9.nipic.com/20100814/2839526  1931471581702.jpg"}
])康聂;
function handleComplete(){
  var image=queue.getResuLt("myImage");
  document.body.appendChild(image);
}

三贰健、懶加載和預(yù)加載的對比

兩者都是提高頁面性能有效的辦法,兩者主要區(qū)別是一個是提前加載恬汁,一個是遲緩甚至不加載伶椿。懶加載對服務(wù)器前端有一定的緩解壓力作用,預(yù)加載則會增加服務(wù)器前端壓力氓侧。

如果覺得文章對你有些許幫助脊另,歡迎在我的GitHub博客點贊和關(guān)注,感激不盡约巷!

四偎痛、參考文章

詳解懶加載和預(yù)加載(js)

懶加載和預(yù)加載

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市独郎,隨后出現(xiàn)的幾起案子看彼,更是在濱河造成了極大的恐慌,老刑警劉巖囚聚,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異标锄,居然都是意外死亡顽铸,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進店門料皇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谓松,“玉大人星压,你說我怎么就攤上這事」砥” “怎么了娜膘?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長优质。 經(jīng)常有香客問我竣贪,道長,這世上最難降的妖魔是什么巩螃? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任演怎,我火速辦了婚禮,結(jié)果婚禮上避乏,老公的妹妹穿的比我還像新娘爷耀。我一直安慰自己,他們只是感情好拍皮,可當我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布歹叮。 她就那樣靜靜地躺著,像睡著了一般铆帽。 火紅的嫁衣襯著肌膚如雪咆耿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天锄贼,我揣著相機與錄音票灰,去河邊找鬼。 笑死宅荤,一個胖子當著我的面吹牛屑迂,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播冯键,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼惹盼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了惫确?” 一聲冷哼從身側(cè)響起手报,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎改化,沒想到半個月后掩蛤,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡陈肛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年揍鸟,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片句旱。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡阳藻,死狀恐怖晰奖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情腥泥,我是刑警寧澤匾南,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站蛔外,受9級特大地震影響蛆楞,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜冒萄,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一臊岸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧尊流,春花似錦帅戒、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至迎献,卻和暖如春瞎访,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背吁恍。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工扒秸, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人冀瓦。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓伴奥,卻偏偏與公主長得像,于是被迫代替她去往敵國和親翼闽。 傳聞我的和親對象是個殘疾皇子拾徙,可洞房花燭夜當晚...
    茶點故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 1、懶加載 1.什么是懶加載感局? 懶加載也就是延遲加載尼啡。當訪問一個頁面的時候,先把img元素或是其他元素的背景圖片路...
    xiaolizhenzhen閱讀 70,474評論 18 160
  • 懶加載和預(yù)加載 1. 懶加載 1. 什么是懶加載询微? 懶加載也就是延遲加載 當訪問一個頁面的時候崖瞭,先把img元素或是...
    琦琦出去玩了閱讀 750評論 0 8
  • 1.懶加載原理 原理:先將img標簽中的src鏈接設(shè)為同一張圖片(空白圖片),將其真正的圖片地址存儲再img標簽的...
    喵媽閱讀 3,345評論 0 3
  • 自動加載 自動加載就是符合某些條件時才加載某些圖片。 現(xiàn)在好多的網(wǎng)站都用到了自動加載圖片技術(shù),比如淘寶寺惫,剛打開淘寶...
    shadow123閱讀 915評論 0 0
  • 故事很早就開始了,并不是我寫出來才有的蹦疑,很早很早之前西雀,他們就在各地,花開歉摧,花落艇肴。你不能說,花是因為我的出現(xiàn)才開放叁温,...
    心理咨詢師郭羽靖閱讀 436評論 0 0