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

JavaScript圖片懶加載的優(yōu)化方法詳解

 更新時間:2022年03月28日 15:39:02   作者:故里有長安丶丶  
這篇文章主要為大家詳細介紹了JavaScript圖片懶加載的優(yōu)化方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

一、方法一

在這里插入圖片描述

重點:

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-自定義標簽,使圖片先不加載*/
    <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ù)的堆積,影響整體效率
})

請?zhí)砑訄D片描述

我們可以看到,雖然圖片懶加載已經(jīng)成功了,但是scroll事件仍在不斷觸發(fā),非常消耗資源,因此目前最推薦使用的方法還是IntersectionObserver

二、方法二 InterSectionObserver

重點:

1.observer.observe(DOM節(jié)點) 觀察哪個DOM節(jié)點

2.observer.unobserve(DOM節(jié)點) 取消觀察某DOM節(jié)點

3.callback目標能看見觸發(fā)一次;目標元素看不見了又觸發(fā)一次

HTML如上

JavaScript:

let img = document.querySelectorAll('img')
//此回調(diào):目標能看見觸發(fā)一次;目標元素看不見了又觸發(fā)一次
const callback = (entries) => {   //接收一個數(shù)組作為參數(shù),數(shù)組每一項都和目標元素相關(guān),比如		isIntersecting判斷目標元素是否被觀察到了,又比如target屬性代表該目標元素
    entries.forEach((item) => {
        //若該目標元素被觀察到了
        if(item.isIntersecting) {
            const img = item.target //目標元素
            const data_src = img.getAttribute('data-src')
            img.setAttribute('src',data_src)
            observer.unobserve(img)  //observer.unobserve(DOM節(jié)點)  取消觀察某DOM節(jié)點
        }
        console.log('觸發(fā)');
    })
}
const observer = new IntersectionObserver(callback)
//遍歷所有img,使得所有img被觀察
img.forEach((item) => {
    observer.observe(item)  //observer.observe(DOM節(jié)點)  觀察哪個DOM節(jié)點
})

思路:

new一個觀察實例,并通過觀察實例身上的observe屬性觀察每一個圖片。定義callback回調(diào)函數(shù),設(shè)置 目標圖片出現(xiàn)時改變屬性

請?zhí)砑訄D片描述

此時我們看到,當所有圖片都懶加載完之后(observe取消觀察DOM節(jié)點),scroll事件就不再觸發(fā)*

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!   。

相關(guān)文章

  • javaScript 邏輯運算符使用技巧整理

    javaScript 邏輯運算符使用技巧整理

    這篇文章主要介紹了javaScript 邏輯運算符使用技巧整理的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • textContent在Firefox下與innerText等效的屬性

    textContent在Firefox下與innerText等效的屬性

    textContent在Firefox下與innerText等效的屬性...
    2007-05-05
  • javascript 構(gòu)建一個xmlhttp對象池合理創(chuàng)建和使用xmlhttp對象

    javascript 構(gòu)建一個xmlhttp對象池合理創(chuàng)建和使用xmlhttp對象

    在我的這篇舊文里曾經(jīng)發(fā)布了一個簡單的ajax操作類。我們發(fā)現(xiàn),在舊文里創(chuàng)建xmlhttp對象的時候,每次都要new一個對象。而我們都知道new一個對象的開銷是很大的。
    2010-01-01
  • 簡單實現(xiàn)JS計算器功能

    簡單實現(xiàn)JS計算器功能

    這篇文章主要教大家簡單實現(xiàn)JS計算器功能,實現(xiàn)小數(shù)點校驗,重復(fù)計算,以及大量更符合用戶體驗的操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • Javascript的this用法

    Javascript的this用法

    本文主要介紹了Javascript的this用法,具有很好的參考價值,有需要了解的朋友可以看看
    2017-01-01
  • js由下向上不斷上升冒氣泡效果實例

    js由下向上不斷上升冒氣泡效果實例

    這篇文章主要介紹了js由下向上不斷上升冒氣泡效果,實例分析了javascript操作鼠標事件、圖片及樣式的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • JavaScript實現(xiàn)多重繼承的方法分析

    JavaScript實現(xiàn)多重繼承的方法分析

    這篇文章主要介紹了JavaScript實現(xiàn)多重繼承的方法,結(jié)合實例形式詳細分析了javascript實現(xiàn)多重繼承的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2018-01-01
  • 使用JS簡單實現(xiàn)apply、call和bind方法的實例代碼

    使用JS簡單實現(xiàn)apply、call和bind方法的實例代碼

    在JavaScript中,call、apply和bind是Function對象自帶的三個方法,這三個方法的主要作用是改變函數(shù)中的this指向,下面這篇文章主要給大家介紹了關(guān)于如何使用JS簡單實現(xiàn)apply、call和bind方法的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • javascript實現(xiàn)的右下角彈窗實例

    javascript實現(xiàn)的右下角彈窗實例

    這篇文章主要介紹了javascript實現(xiàn)的右下角彈窗,實例分析了javascript實現(xiàn)右下角彈窗的完整實現(xiàn)步驟與技巧,需要的朋友可以參考下
    2015-04-04
  • 詳解http訪問解析流程原理

    詳解http訪問解析流程原理

    這篇文章主要介紹了詳解http訪問解析流程原理的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10

最新評論