首頁 web前端 js教程 如何使用HTML、CSS和jQuery實作圖懶載入的進階技巧

如何使用HTML、CSS和jQuery實作圖懶載入的進階技巧

Oct 28, 2023 am 08:25 AM
css html 圖片懶加載

如何使用HTML、CSS和jQuery實作圖懶載入的進階技巧

如何使用HTML、CSS和jQuery實作圖片懶載入的進階技巧

懶載入技術(Lazy Loading)是一種提升網頁效能的技術手段,特別適用於包含大量圖片的網頁。透過使用HTML、CSS和jQuery,我們可以輕鬆實現圖片懶加載,以加快網頁載入速度,提升使用者體驗。本文將介紹如何使用這三種技術實現圖片懶加載的進階技巧,並給出具體的程式碼範例。

一、HTML準備工作
在HTML中,我們需要將每個需要懶載入的圖片的src屬性替換為一個自訂的data-src屬性。同時,為了實現圖片漸進式載入效果,我們可以設定一個佔位圖(placeholder)。

<img src="/static/imghw/default1.png"  data-src="path/to/image.jpg"  class="lazy"  data- alt="image">
登入後複製

二、CSS樣式設定
為了在圖片載入前保持佔位圖的展示,我們需要使用CSS對img元素進行設定。同時,為了實現漸進式加載效果,我們還可以設定過渡效果。

img {
  width: 100%;
  height: auto;
  max-width: 100%;
  opacity: 0;
  transition: opacity 0.3s ease-in;
}
img.loaded {
  opacity: 1;
}
登入後複製

三、jQuery實作懶載入
使用jQuery來實作懶載入非常簡單。我們可以使用$(window).on('scroll', function(){})事件監聽滾動事件,並透過判斷圖片是否可見來觸發懶加載。

$(window).on('scroll', function() {
  $('img').each(function() {
    if (isElementInViewport($(this)) && !$(this).hasClass('loaded')) {
      $(this).attr('src', $(this).data('src')).addClass('loaded');
    }
  });
});
function isElementInViewport(el) {
  var rect = el.get(0).getBoundingClientRect();
  return (
    rect.top >= 0 &&
    rect.left >= 0 &&
    rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) &&
    rect.right <= (window.innerWidth || document.documentElement.clientWidth)
  );
}
登入後複製

以上程式碼會監聽滾動事件,並對每個img元素進行判斷,如果該元素在可視區域內且未加載過,則將data-src屬性的值賦給src,並添加loaded類別名稱以標記已載入。

四、片段加載及效能最佳化
為了進一步提高效能,我們可以將圖片分成多個片段進行加載,而不是一次載入所有圖片。這樣可以避免頁面一次要求大量圖片而導致的效能問題。

$(window).on('scroll', function() {
  var windowHeight = $(window).height();
  var scrollTop = $(window).scrollTop();
  $('img:not(.loaded)').each(function() {
    if (isElementInViewport($(this), windowHeight, scrollTop)) {
      $(this).attr('src', $(this).data('src')).addClass('loaded');
    }
  });
});
function isElementInViewport(el, windowHeight, scrollTop) {
  var rect = el.get(0).getBoundingClientRect();
  return (
    rect.top >= (scrollTop - windowHeight) &&
    rect.top <= (scrollTop + windowHeight * 2)
  );
}
登入後複製

以上程式碼中,我們透過取得視窗的高度和捲軸的位置,判斷每張圖片是否在視覺區域內。只有在可視區域內的圖片才會被載入。

綜上所述,透過使用HTML、CSS和jQuery,我們可以輕鬆地實現圖片懶載入的進階技巧,並提高網頁的載入速度與使用者體驗。透過設定自訂的data-src屬性、CSS樣式和jQuery事件監聽,以及結合片段載入和效能最佳化,我們可以更靈活地控制圖片的載入行為,提升使用者體驗和頁面效能。希望本文所提供的程式碼範例能對您有所幫助!

以上是如何使用HTML、CSS和jQuery實作圖懶載入的進階技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

vue中怎麼用bootstrap vue中怎麼用bootstrap Apr 07, 2025 pm 11:33 PM

在 Vue.js 中使用 Bootstrap 分為五個步驟:安裝 Bootstrap。在 main.js 中導入 Bootstrap。直接在模板中使用 Bootstrap 組件。可選:自定義樣式。可選:使用插件。

HTML,CSS和JavaScript的角色:核心職責 HTML,CSS和JavaScript的角色:核心職責 Apr 08, 2025 pm 07:05 PM

HTML定義網頁結構,CSS負責樣式和佈局,JavaScript賦予動態交互。三者在網頁開發中各司其職,共同構建豐富多彩的網站。

bootstrap怎麼寫分割線 bootstrap怎麼寫分割線 Apr 07, 2025 pm 03:12 PM

創建 Bootstrap 分割線有兩種方法:使用 標籤,可創建水平分割線。使用 CSS border 屬性,可創建自定義樣式的分割線。

bootstrap怎麼調整大小 bootstrap怎麼調整大小 Apr 07, 2025 pm 03:18 PM

要調整 Bootstrap 中元素大小,可以使用尺寸類,具體包括:調整寬度:.col-、.w-、.mw-調整高度:.h-、.min-h-、.max-h-

bootstrap怎麼插入圖片 bootstrap怎麼插入圖片 Apr 07, 2025 pm 03:30 PM

在 Bootstrap 中插入圖片有以下幾種方法:直接插入圖片,使用 HTML 的 img 標籤。使用 Bootstrap 圖像組件,可以提供響應式圖片和更多樣式。設置圖片大小,使用 img-fluid 類可以使圖片自適應。設置邊框,使用 img-bordered 類。設置圓角,使用 img-rounded 類。設置陰影,使用 shadow 類。調整圖片大小和位置,使用 CSS 樣式。使用背景圖片,使用 background-image CSS 屬性。

bootstrap怎麼設置框架 bootstrap怎麼設置框架 Apr 07, 2025 pm 03:27 PM

要設置 Bootstrap 框架,需要按照以下步驟:1. 通過 CDN 引用 Bootstrap 文件;2. 下載文件並將其託管在自己的服務器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根據需要編譯 Sass/Less;5. 導入定製文件(可選)。設置完成後,即可使用 Bootstrap 的網格系統、組件和样式創建響應式網站和應用程序。

bootstrap怎麼看日期 bootstrap怎麼看日期 Apr 07, 2025 pm 03:03 PM

答案:可以使用 Bootstrap 的日期選擇器組件在頁面中查看日期。步驟:引入 Bootstrap 框架。在 HTML 中創建日期選擇器輸入框。 Bootstrap 將自動為選擇器添加樣式。使用 JavaScript 獲取選定的日期。

bootstrap按鈕怎麼用 bootstrap按鈕怎麼用 Apr 07, 2025 pm 03:09 PM

如何使用 Bootstrap 按鈕?引入 Bootstrap CSS創建按鈕元素並添加 Bootstrap 按鈕類添加按鈕文本

See all articles