当前位置: 首页 > news >正文

前端骨架怎样实现

前端骨架屏(Skeleton Screen)是一种优化页面加载体验的技术,通常在内容加载时展示一个简易的占位符,避免用户看到空白页面。骨架屏通过展示页面结构的骨架样式,让用户有页面正在加载的感觉,而不是等待内容加载完毕。常见的骨架屏实现方式有两种:使用 CSS 动画和使用 JavaScript 组件。

基本实现步骤:

  1. 设计骨架结构
    骨架屏的结构应该根据你页面的内容来设计,常见的有文本框、头像、图片等元素。可以使用灰色或浅色背景来模拟真实内容的占位。

  2. 使用 CSS 实现动画效果
    使用 @keyframes 来创建渐变动画效果,使骨架屏看起来更流畅。

  3. 用 React 组件动态渲染骨架屏
    使用 React 或其他框架,基于数据加载状态(如 loading)来控制显示骨架屏还是实际内容。

例子:用 React 和 CSS 实现一个简单的骨架屏

1. 创建骨架屏组件
import React from 'react';
import './Skeleton.css';

const Skeleton = () => {
  return (
    <div className="skeleton-wrapper">
      <div className="skeleton-avatar"></div>
      <div className="skeleton-text"></div>
      <div className="skeleton-text"></div>
      <div className="skeleton-button"></div>
    </div>
  );
}

export default Skeleton;
2. 添加 CSS 样式
.skeleton-wrapper {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.skeleton-avatar {
  width: 60px;
  height: 60px;
  background: #e0e0e0;
  border-radius: 50%;
  animation: skeleton-loading 1.5s infinite ease-in-out;
}

.skeleton-text {
  width: 100%;
  height: 20px;
  background: #e0e0e0;
  border-radius: 4px;
  animation: skeleton-loading 1.5s infinite ease-in-out;
}

.skeleton-button {
  width: 120px;
  height: 36px;
  background: #e0e0e0;
  border-radius: 6px;
  animation: skeleton-loading 1.5s infinite ease-in-out;
}

@keyframes skeleton-loading {
  0% {
    background: #e0e0e0;
  }
  50% {
    background: #f0f0f0;
  }
  100% {
    background: #e0e0e0;
  }
}
3. 使用骨架屏组件

在你加载数据时,使用骨架屏作为占位符,直到数据加载完毕。

import React, { useState, useEffect } from 'react';
import Skeleton from './Skeleton';

const UserProfile = () => {
  const [data, setData] = useState(null);

  useEffect(() => {
    setTimeout(() => {
      setData({
        avatar: 'https://randomuser.me/api/portraits/men/1.jpg',
        name: 'John Doe',
        bio: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.',
      });
    }, 2000); // 模拟延迟加载
  }, []);

  return (
    <div>
      {data ? (
        <div>
          <img src={data.avatar} alt="Avatar" />
          <h2>{data.name}</h2>
          <p>{data.bio}</p>
        </div>
      ) : (
        <Skeleton />
      )}
    </div>
  );
};

export default UserProfile;

其他优化

  • 骨架屏类型
    • 灰度骨架屏:展示灰色或其他单色块,不显示内容。
    • 内容骨架屏:以实际内容的格式展示占位符,如模拟列表、文章的标题和段落。
  • 库支持:如果想要一个更精细的骨架屏,可以使用一些现成的库,比如 react-loading-skeleton@mui/material 自带的骨架屏组件。
参考库
  • react-loading-skeleton: 提供了简单的骨架屏组件,支持自定义样式和动画效果。
  • @mui/material Skeleton: Material UI 的骨架屏组件,适用于 Material Design 风格的应用。

这样可以大大提升用户体验,避免长时间等待内容加载时的空白页面。你目前有在做这个功能吗?

相关文章:

  • 【DeepSeek】DeepSeek概述 | 本地部署deepseek
  • DeepSeek笔记(一):本地部署DeepSeek R1并搭建Web UI实现可视化交互的笔记
  • 开源模型应用落地-Qwen1.5-MoE-A2.7B-Chat与vllm实现推理加速的正确姿势(一)
  • GPT 系列模型发展史:从 GPT 到 ChatGPT 的演进与技术细节
  • STM32 裸机 C编程 vs micropython编程 vs linux python
  • 【Linux】网络基础
  • 西安电子科技大学考研成绩2月24号即可查询,成绩查询入口:
  • Spring Boot比Spring多哪些注解?
  • 漏洞挖掘 | 基于mssql数据库的sql注入
  • Linux(Centos 7.6)命令详解:head
  • 安装并配置 MySQL
  • 大数据、人工智能、云计算、物联网、区块链序言【大数据导论】
  • Repo命令使用
  • 【Elasticsearch】token filter分词过滤器
  • MongoDB 扩缩容实战:涵盖节点配置、服务启动与移除操作
  • Centos7安装Tesseract5.5.0+SpringBoot集成部署(离线版)
  • 初识计算机网络
  • 企语企业管理系iFair(F23.2_a0)在Debian操作系统中的安装
  • 在Mac M1上面安装Miniconda
  • 【AI】在Ubuntu中使用docker对DeepSeek的部署与使用
  • 印度一战机在巴基斯坦旁遮普省被击落,飞行员被俘
  • 华泰柏瑞基金总经理韩勇因工作调整卸任,董事长贾波代为履职
  • 中非民间对话在赞比亚举行
  • 47本笔记、2341场讲座,一位普通上海老人的阅读史
  • 无人机穿越大理千年古塔落券洞内,涉事“飞手”被行拘10日
  • 中华人民共和国和俄罗斯联邦关于进一步加强合作维护国际法权威的联合声明