深入浅出骨架屏实现原理

一、什么是骨架屏

骨架屏,也叫做“占位图”,是一种在页面加载过程中展示出页面基础框架,提高用户体验的技术。它所展示的页面框架与真实内容对应,好比是一个未完成的画,给用户以更直观的印象。骨架屏技术的应用已非常广泛,特别是在电商行业,能够提升产品详情页的转化率。

二、骨架屏的优点

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/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

发表回复

登录后才能评论