詳解JavaScript兩個(gè)實(shí)用的圖片懶加載優(yōu)化方法
一、方法一

重點(diǎn):
1.getBoundingClientRect().top > window.innerHeight 圖片未出現(xiàn)2.getBoundingClientRect().top < window.innerHeight 圖片出現(xiàn)了
HTML:
<ul>
......
<li>2222222222</li>
<li>2222222222</li>
<li>2222222222</li>
<li>2222222222</li>
<li>2222222222</li>
<li>2222222222</li>
/*先用data-自定義標(biāo)簽,使圖片先不加載*/
<img data-src="./img1.jpg" height="200px"><br>
<img data-src="./img2.jpg" height="200px" alt=""><br>
<img data-src="./img3.jpg" height="200px" alt="">
</ul>
JavaScript:
let img = document.querySelectorAll('img')
window.addEventListener('scroll',() => {
img.forEach((item) => {
//若圖片頂部高度小于視窗高度
if(item.getBoundingClientRect().top < window.innerHeight) {
const data_src = item.getAttribute('data-src')
//則將自定義屬性data-src賦值給src屬性
item.setAttribute("src",data_src)
}
})
console.log("scroll觸發(fā)了"); //此方法:若加載很多內(nèi)容,就會導(dǎo)致任務(wù)的堆積,影響整體效率
})

我們可以看到,雖然圖片懶加載已經(jīng)成功了,但是scroll事件仍在不斷觸發(fā),非常消耗資源,因此目前最推薦使用的方法還是IntersectionObserver
二、方法二 InterSectionObserver
重點(diǎn):
1.observer.observe(DOM節(jié)點(diǎn)) 觀察哪個(gè)DOM節(jié)點(diǎn)2.observer.unobserve(DOM節(jié)點(diǎn)) 取消觀察某DOM節(jié)點(diǎn)3.callback目標(biāo)能看見觸發(fā)一次;目標(biāo)元素看不見了又觸發(fā)一次
HTML如上
JavaScript:
let img = document.querySelectorAll('img')
//此回調(diào):目標(biāo)能看見觸發(fā)一次;目標(biāo)元素看不見了又觸發(fā)一次
const callback = (entries) => { //接收一個(gè)數(shù)組作為參數(shù),數(shù)組每一項(xiàng)都和目標(biāo)元素相關(guān),比如 isIntersecting判斷目標(biāo)元素是否被觀察到了,又比如target屬性代表該目標(biāo)元素
entries.forEach((item) => {
//若該目標(biāo)元素被觀察到了
if(item.isIntersecting) {
const img = item.target //目標(biāo)元素
const data_src = img.getAttribute('data-src')
img.setAttribute('src',data_src)
observer.unobserve(img) //observer.unobserve(DOM節(jié)點(diǎn)) 取消觀察某DOM節(jié)點(diǎn)
}
console.log('觸發(fā)');
})
}
const observer = new IntersectionObserver(callback)
//遍歷所有img,使得所有img被觀察
img.forEach((item) => {
observer.observe(item) //observer.observe(DOM節(jié)點(diǎn)) 觀察哪個(gè)DOM節(jié)點(diǎn)
})
思路:
new一個(gè)觀察實(shí)例,并通過觀察實(shí)例身上的observe屬性觀察每一個(gè)圖片。定義callback回調(diào)函數(shù),設(shè)置 目標(biāo)圖片出現(xiàn)時(shí)改變屬性

此時(shí)我們看到,當(dāng)所有圖片都懶加載完之后(observe取消觀察DOM節(jié)點(diǎn)),scroll事件就不再觸發(fā)*
到此這篇關(guān)于詳解JavaScript兩個(gè)實(shí)用的圖片懶加載優(yōu)化方法的文章就介紹到這了,更多相關(guān)JavaScript 圖片懶加載優(yōu)化 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Javascript代碼實(shí)現(xiàn)仿實(shí)例化類
這篇文章主要介紹了Javascript代碼實(shí)現(xiàn)仿實(shí)例化類的相關(guān)資料并附上示例,非常不錯(cuò)的文章,需要的朋友可以參考下2015-04-04
JavaScript 瀏覽器兼容性總結(jié)及常用瀏覽器兼容性分析
本文是腳本之家小編日常整理些關(guān)于js兼容性問題,及IE與Firefox等常用瀏覽器的兼容性分析,對js瀏覽器兼容性相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧2016-03-03
基于JS快速實(shí)現(xiàn)導(dǎo)航下拉菜單動(dòng)畫效果附源碼下載
這是一個(gè)帶變形動(dòng)畫特效的下拉導(dǎo)航菜單特效。該導(dǎo)航菜單在菜單項(xiàng)之間切換時(shí),下拉菜單會快速的根據(jù)菜單內(nèi)容的大小來動(dòng)態(tài)變形,顯示合適的下拉菜單大小,效果非常棒,對導(dǎo)航下拉菜單效果感興趣的朋友一起通過本文學(xué)習(xí)吧2016-10-10
javascript解決小數(shù)的加減乘除精度丟失的方案
這篇文章主要介紹了javascript解決小數(shù)的加減乘除精度丟失的方案的相關(guān)資料以及JavaScript中關(guān)于丟失數(shù)字精度的問題的探討,非常的詳細(xì),需要的朋友可以參考下2016-05-05
JavaScript移動(dòng)端常用事件之touch觸摸事件詳解
觸屏事件touch也稱為觸摸事件,touch對象代表一個(gè)觸摸點(diǎn),觸摸點(diǎn)可能是一根手指,也可能是一根觸摸筆,觸屏事件可響應(yīng)用戶手指(或觸摸筆)對屏幕或者觸控板操作,下面這篇文章主要給大家介紹了關(guān)于JavaScript移動(dòng)端常用事件之touch觸摸事件的相關(guān)資料,需要的朋友可以參考下2022-10-10
JavaScript中三個(gè)等號和兩個(gè)等號你了解多少
本篇文章主要介紹了js里面的==和===,== 判斷如果兩邊變量的類型不同,而 === 則不做類型轉(zhuǎn)換,有興趣的可以了解一下2017-07-07
JavaScript宏任務(wù)和微任務(wù)區(qū)別介紹
這篇文章主要介紹了JavaScript宏任務(wù)和微任務(wù)區(qū)別介紹,js中的任務(wù),大致分為2類,一類是同步任務(wù),另一類是異步任務(wù)。而異步任務(wù),又分為宏任務(wù)和微任務(wù),這兩個(gè)任務(wù)是兩個(gè)隊(duì)列,所以是先進(jìn)先出的2022-07-07

