基于JavaScript+IntersectionObserver實(shí)現(xiàn)高性能圖片懶加載
一、前言
在 Web 開(kāi)發(fā)中,圖片懶加載是一種常見(jiàn)的優(yōu)化手段,尤其在長(zhǎng)列表頁(yè)面中,按需加載圖片可以顯著提升頁(yè)面性能。本篇文章將通過(guò) JavaScript 和 Intersection Observer,實(shí)現(xiàn)一個(gè)帶有卡片樣式的高性能圖片懶加載示例。
二、樣式布局
以下是卡片列表的樣式,采用了 CSS Grid 布局,支持響應(yīng)式排列,并為圖片卡片添加了縮放動(dòng)畫(huà)效果:
body {
background-color: #f5f6f7;
}
.card-list {
--ap-gap: 16px; /* 列表項(xiàng)的間距 */
--ap-min-width: 300px; /* 列表項(xiàng)的最小寬度 */
display: grid;
grid-template-columns: repeat(auto-fill, minmax(var(--ap-min-width), 1fr));
gap: var(--ap-gap);
padding: 16px;
}
.card-list .item {
cursor: pointer;
height: 497px;
border-radius: 10px;
box-shadow: 0 0 6px #000;
overflow: hidden;
}
.card-list .item:hover img {
transform: scale(1.5);
}
.card-list .item img {
display: block;
width: 100%;
height: 100%;
transition: all 0.32s;
}
上述樣式不僅定義了圖片卡片的基本外觀,還支持鼠標(biāo)懸停時(shí)的動(dòng)態(tài)縮放效果,提升了用戶體驗(yàn)。
三、HTML 結(jié)構(gòu)
頁(yè)面結(jié)構(gòu)簡(jiǎn)單明了,通過(guò) JavaScript 動(dòng)態(tài)生成卡片列表:
<div class="card-list"></div>
四、實(shí)現(xiàn)邏輯
1、配置項(xiàng)與生成圖片卡片
通過(guò)以下代碼,動(dòng)態(tài)生成 99 張圖片卡片,使用默認(rèn)占位圖提高頁(yè)面加載速度:
const TOTAL_ITEMS = 99;
const DEFAULT_IMG = './img/default.jpg';
const IMG_URL_TEMPLATE = (index) => `https://picsum.photos/400/600?r=${index}`;
const cardList = document.querySelector('.card-list');
function generateItems() {
const fragment = document.createDocumentFragment();
for (let i = 0; i < TOTAL_ITEMS; i++) {
const div = document.createElement('div');
div.classList.add('item');
const img = document.createElement('img');
img.src = DEFAULT_IMG;
img.dataset.src = IMG_URL_TEMPLATE(i);
img.alt = `Image ${i + 1}`;
div.appendChild(img);
fragment.appendChild(div);
}
cardList.appendChild(fragment);
}
generateItems();
2、使用 Intersection Observer 實(shí)現(xiàn)懶加載
通過(guò) Intersection Observer,可以高效檢測(cè)圖片是否進(jìn)入視口,并在合適的時(shí)機(jī)加載真實(shí)圖片:
function initLazyLoad() {
const observer = new IntersectionObserver(
(entries, observer) => {
entries.forEach((entry) => {
if (!entry.isIntersecting) return;
const img = entry.target;
img.src = img.dataset.src;
observer.unobserve(img);
});
},
{ threshold: 0.01 }
);
document.querySelectorAll('img[data-src]').forEach((img) => observer.observe(img));
}
initLazyLoad();
本文通過(guò)樣式優(yōu)化和 Intersection Observer,有效提升了圖片懶加載的性能,同時(shí)保持了良好的用戶體驗(yàn)。這種實(shí)現(xiàn)方式不僅適用于圖片懶加載,也可以擴(kuò)展到其它按需加載場(chǎng)景,如視頻或組件加載。
到此這篇關(guān)于基于JavaScript+IntersectionObserver實(shí)現(xiàn)高性能圖片懶加載的文章就介紹到這了,更多相關(guān)JavaScript IntersectionObserver圖片懶加載內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js 將canvas生成圖片保存,或直接保存一張圖片的實(shí)現(xiàn)方法
下面小編就為大家分享一篇js 將canvas生成圖片保存,或直接保存一張圖片的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
淺析JS刷新框架中的其他頁(yè)面 && JS刷新窗口方法匯總
本篇文章是對(duì)JS刷新框架中的其他頁(yè)面以及JS刷新窗口的方法進(jìn)行了匯總介紹,需要的朋友可以參考下2013-07-07
javascript實(shí)現(xiàn)前端input密碼輸入強(qiáng)度驗(yàn)證
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)前端input密碼輸入強(qiáng)度驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06
使用微信小程序顯示用戶當(dāng)前地理位置的詳細(xì)代碼
這篇文章主要介紹了使用微信小程序顯示用戶當(dāng)前地理位置的詳細(xì)代碼,在微信小程序的開(kāi)發(fā)中不可避免的會(huì)遇到需要顯示用戶地理位置的操作,本文將簡(jiǎn)單介紹如何在微信小程序中顯示用戶當(dāng)前的地理位置,需要的朋友可以參考下2022-06-06
對(duì)于Form表單reset方法的新認(rèn)識(shí)
HTML中Form表單的reset方法被用來(lái)清空用戶所輸入的內(nèi)容,以前一直誤以為其是單純的將input等輸入項(xiàng)中的值清空2014-03-03
JS前端開(kāi)發(fā)判斷是否是手機(jī)端并跳轉(zhuǎn)操作(小結(jié))
這篇文章主要介紹了JS前端開(kāi)發(fā)判斷是否是手機(jī)端并跳轉(zhuǎn)操作,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02

