基于JavaScript+IntersectionObserver實現高性能圖片懶加載
一、前言
在 Web 開發(fā)中,圖片懶加載是一種常見的優(yōu)化手段,尤其在長列表頁面中,按需加載圖片可以顯著提升頁面性能。本篇文章將通過 JavaScript 和 Intersection Observer,實現一個帶有卡片樣式的高性能圖片懶加載示例。
二、樣式布局
以下是卡片列表的樣式,采用了 CSS Grid 布局,支持響應式排列,并為圖片卡片添加了縮放動畫效果:
body { background-color: #f5f6f7; } .card-list { --ap-gap: 16px; /* 列表項的間距 */ --ap-min-width: 300px; /* 列表項的最小寬度 */ 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; }
上述樣式不僅定義了圖片卡片的基本外觀,還支持鼠標懸停時的動態(tài)縮放效果,提升了用戶體驗。
三、HTML 結構
頁面結構簡單明了,通過 JavaScript 動態(tài)生成卡片列表:
<div class="card-list"></div>
四、實現邏輯
1、配置項與生成圖片卡片
通過以下代碼,動態(tài)生成 99 張圖片卡片,使用默認占位圖提高頁面加載速度:
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 實現懶加載
通過 Intersection Observer,可以高效檢測圖片是否進入視口,并在合適的時機加載真實圖片:
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();
本文通過樣式優(yōu)化和 Intersection Observer,有效提升了圖片懶加載的性能,同時保持了良好的用戶體驗。這種實現方式不僅適用于圖片懶加載,也可以擴展到其它按需加載場景,如視頻或組件加載。
到此這篇關于基于JavaScript+IntersectionObserver實現高性能圖片懶加載的文章就介紹到這了,更多相關JavaScript IntersectionObserver圖片懶加載內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
js 將canvas生成圖片保存,或直接保存一張圖片的實現方法
下面小編就為大家分享一篇js 將canvas生成圖片保存,或直接保存一張圖片的實現方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01