前端骨架屏(Skeleton Screen)是一种优化页面加载体验的技术,通常在内容加载时展示一个简易的占位符,避免用户看到空白页面。骨架屏通过展示页面结构的骨架样式,让用户有页面正在加载的感觉,而不是等待内容加载完毕。常见的骨架屏实现方式有两种:使用 CSS 动画和使用 JavaScript 组件。
基本实现步骤:
-
设计骨架结构
骨架屏的结构应该根据你页面的内容来设计,常见的有文本框、头像、图片等元素。可以使用灰色或浅色背景来模拟真实内容的占位。 -
使用 CSS 实现动画效果
使用@keyframes
来创建渐变动画效果,使骨架屏看起来更流畅。 -
用 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 风格的应用。
这样可以大大提升用户体验,避免长时间等待内容加载时的空白页面。你目前有在做这个功能吗?