深入淺出骨架屏實現原理

一、什麼是骨架屏

骨架屏,也叫做「佔位圖」,是一種在頁面加載過程中展示出頁面基礎框架,提高用戶體驗的技術。它所展示的頁面框架與真實內容對應,好比是一個未完成的畫,給用戶以更直觀的印象。骨架屏技術的應用已非常廣泛,特別是在電商行業,能夠提升產品詳情頁的轉化率。

二、骨架屏的優點

1. 提高用戶體驗:骨架屏的使用能讓用戶在頁面加載過程中看到基礎框架,使用戶體驗更加流暢自然。

2. 減輕服務器壓力:當頁面請求的數據很多時,骨架屏可以先展示,等到數據加載完成再將骨架屏替換成內容,減輕了服務器的壓力。

3. 優化 SEO:搜索引擎爬蟲能夠識別 HTML 中的標籤,骨架屏包含基礎的 HTML 結構,可以幫助搜索引擎優化。

三、骨架屏實現的方法

實現骨架屏的方法有很多,包括基於 PWA 技術的模板生成方案、基於 Vue 的骨架屏生成方案、基於 React 的骨架屏生成方案等。下面講解一種比較簡單的實現方法。

四、骨架屏實現步驟

步驟 1:首先我們需要將頁面元素分類,將其按照頁面元素的類型分成若干組,比如頭部、導航欄、Banner、列表、底部等。


<!-- 骨架屏HTML代碼 -->
<div class="header"></div>
<div class="nav"></div>
<div class="banner"></div>
<ul class="list"></ul>
<div class="footer"></div>

步驟 2:在 CSS 中我們通過特定的樣式去模擬這些組件的樣式。我們可以使用偽類及 background 屬性等去模擬。


/* 頭部 */
.header{
  width: 100%;
  height: 50px;
  background: #f2f2f2;
}

/* 導航欄 */
.nav{
  width: 100%;
  height: 80px;
  background: #f2f2f2;
}

/* Banner */
.banner{
  width: 100%;
  height: 400px;
  background: #f2f2f2;
}

/* 列表 */
.list{
  width: 100%;
  height: 400px;
  background: #f2f2f2;
}

/* 底部 */
.footer{
  width: 100%;
  height: 50px;
  background: #f2f2f2;
}

步驟 3:接下來,在 JS 中,可以通過遍歷頁面元素,將每個元素的 class 屬性替換為對應的「骨架屏」,以實現骨架屏的效果。以下是示例 JS 代碼:


window.onload = function(){
  var skeletonElement = document.querySelectorAll('.skeleton');

  for(var i = skeletonElement.length - 1; i >= 0; i--) {
      var skeletonNode = skeletonElement[i];
      var skeletonCopyNode = skeletonNode.cloneNode(true);
      skeletonCopyNode.className += " skeleton" + i;
      skeletonCopyNode.style.position = "absolute";
      skeletonCopyNode.style.left = skeletonNode.offsetLeft + "px";
      skeletonCopyNode.style.top = skeletonNode.offsetTop + "px";
      skeletonCopyNode.style.width = skeletonNode.offsetWidth + "px";
      skeletonCopyNode.style.height = skeletonNode.offsetHeight + "px";
      skeletonCopyNode.style.zIndex = "999";
      skeletonCopyNode.style.backgroundSize = "200% 100%";
      skeletonNode.parentNode.appendChild(skeletonCopyNode);
  }
  var skeletonElementDelay = document.querySelectorAll('.skeleton-delay');

  for(var i = skeletonElementDelay.length - 1; i >= 0; i--) {
    var skeletonDelayNode = skeletonElementDelay[i];
    var skeletonDelayCopyNode = skeletonDelayNode.cloneNode(true);
    skeletonDelayCopyNode.className += " skeleton-delay" + i;
    skeletonDelayCopyNode.style.position = "absolute";
    skeletonDelayCopyNode.style.left = skeletonDelayNode.offsetLeft + "px";
    skeletonDelayCopyNode.style.top = skeletonDelayNode.offsetTop + "px";
    skeletonDelayCopyNode.style.width = skeletonDelayNode.offsetWidth + "px";
    skeletonDelayCopyNode.style.height = skeletonDelayNode.offsetHeight + "px";
    skeletonDelayCopyNode.style.backgroundColor = "transparent";
    skeletonDelayCopyNode.style.border = "1px solid #f2f2f2";
    skeletonDelayCopyNode.style.borderRadius = "4px";
    skeletonDelayCopyNode.style.zIndex = "999";
    skeletonDelayCopyNode.style.animation = "skeleton-delay .5s ease-in-out forwards";
    skeletonDelayNode.parentNode.appendChild(skeletonDelayCopyNode);
  }
}

通過以上代碼,我們可以看到,JS 中的核心操作是關於頁面元素的遍歷,將遍歷到的元素的 class 屬性替換成對應的「骨架屏」,並賦予對應的樣式。

五、骨架屏實現的注意事項

1. 「骨架屏」元素與真實內容元素的 class 名稱應當一致,以便於對應。

2. 骨架屏通常使用灰色作為背景色。

3. 當真實內容過多時,可以設置動態的骨架屏。

4. 不同元素的骨架屏樣式應當區分開來,以便於用戶更好地感知頁面內容加載的狀態。

5. 當數據加載完成後,應當將骨架屏節點進行刪除,將真實內容節點進行展示。

結語

骨架屏技術可以極大提升用戶體驗,在頁面加載內容過程中讓用戶感受到更優美的效果。不同的骨架屏實現方案有其不同的優缺點,開發者可以根據實際業務需求進行選擇。希望本文能為讀者提供有價值的幫助。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/307281.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2025-01-02 18:06
下一篇 2025-01-02 18:06

相關推薦

  • Harris角點檢測算法原理與實現

    本文將從多個方面對Harris角點檢測算法進行詳細的闡述,包括算法原理、實現步驟、代碼實現等。 一、Harris角點檢測算法原理 Harris角點檢測算法是一種經典的計算機視覺算法…

    編程 2025-04-29
  • 瘦臉算法 Python 原理與實現

    本文將從多個方面詳細闡述瘦臉算法 Python 實現的原理和方法,包括該算法的意義、流程、代碼實現、優化等內容。 一、算法意義 隨着科技的發展,瘦臉算法已經成為了人們修圖中不可缺少…

    編程 2025-04-29
  • 神經網絡BP算法原理

    本文將從多個方面對神經網絡BP算法原理進行詳細闡述,並給出完整的代碼示例。 一、BP算法簡介 BP算法是一種常用的神經網絡訓練算法,其全稱為反向傳播算法。BP算法的基本思想是通過正…

    編程 2025-04-29
  • GloVe詞向量:從原理到應用

    本文將從多個方面對GloVe詞向量進行詳細的闡述,包括其原理、優缺點、應用以及代碼實現。如果你對詞向量感興趣,那麼這篇文章將會是一次很好的學習體驗。 一、原理 GloVe(Glob…

    編程 2025-04-27
  • 編譯原理語法分析思維導圖

    本文將從以下幾個方面詳細闡述編譯原理語法分析思維導圖: 一、語法分析介紹 1.1 語法分析的定義 語法分析是編譯器中將輸入的字符流轉換成抽象語法樹的一個過程。該過程的目的是確保輸入…

    編程 2025-04-27
  • Python字典底層原理用法介紹

    本文將以Python字典底層原理為中心,從多個方面詳細闡述。字典是Python語言的重要組成部分,具有非常強大的功能,掌握其底層原理對於學習和使用Python將是非常有幫助的。 一…

    編程 2025-04-25
  • Grep 精準匹配:探究匹配原理和常見應用

    一、什麼是 Grep 精準匹配 Grep 是一款在 Linux 系統下常用的文本搜索和處理工具,精準匹配是它最常用的一個功能。Grep 精準匹配是指在一個文本文件中查找與指定模式完…

    編程 2025-04-25
  • 深入探討馮諾依曼原理

    一、原理概述 馮諾依曼原理,又稱「存儲程序控制原理」,是指計算機的程序和數據都存儲在同一個存儲器中,並且通過一個統一的總線來傳輸數據。這個原理的提出,是計算機科學發展中的重大進展,…

    編程 2025-04-25
  • 深入淺出統計學

    統計學是一門關於收集、分析、解釋和呈現數據的學科。它在各行各業都有廣泛應用,包括社會科學、醫學、自然科學、商業、經濟學、政治學等等。深入淺出統計學是指想要學習統計學的人能夠理解統計…

    編程 2025-04-25
  • 樸素貝葉斯原理詳解

    一、樸素貝葉斯基礎 樸素貝葉斯是一種基於貝葉斯定理的算法,用於分類和預測。貝葉斯定理是一種計算條件概率的方法,即已知某些條件下,某事件發生的概率,求某條件下另一事件發生的概率。樸素…

    編程 2025-04-25

發表回復

登錄後才能評論