HTML & CSS:手把手教你实现骨架屏效果

效果演示

这个 HTML 和 CSS 代码创建了一个模拟加载效果的卡片,包含一个主加载条和两个辅助的加载条,用来模拟数据加载的过程。(骨架屏: 在需要等待加载内容的位置设置一个骨架屏,某些场景下比 Loading 的视觉效果更好。)

HTML

html 复制代码
<div class="card">
    <div class="card_load"></div>
    <div class="card_load_extreme_title"></div>
    <div class="card_load_extreme_descripion"></div>
</div>
  • card:作为卡片的容器,包含三个子元素:card_load、card_load_extreme_title和card_load_extreme_descripion。
  • card_load:代表主加载条,显示在卡片的最左侧。
  • card_load_extreme_title和card_load_extreme_descripion:分别代表卡片标题和描述的加载条,显示在卡片的右侧。

CSS

css 复制代码
.card {
  width: 190px;
  height: 90px;
  background: #ffff;
  box-shadow: 0 1px 25px rgba(0,0,0,0.2);
  position: absolute;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  padding: 12px 10px;
  border-radius: 5px;
}

.card_load {
  width: 70px;
  height: 70px;
  position: relative;
  float: left;
  background: linear-gradient(120deg, #e5e5e5 30%, #f0f0f0 38%, #f0f0f0
  40%, #e5e5e5 48%);
  border-radius: 50%;
  background-size: 200% 100%;
  background-position: 100% 0;
  animation: load89234 2s infinite;
}

.card_load_extreme_title {
  width: 90px;
  height: 10px;
  position: relative;
  float: right;
  border-radius: 5px;
  background: linear-gradient(120deg, #e5e5e5 30%, #f0f0f0 38%, #f0f0f0
  40%, #e5e5e5 48%);
  background-size: 200% 100%;
  background-position: 100% 0;
  animation: load89234 2s infinite;
}

.card_load_extreme_descripion {
  width: 90px;
  height: 47px;
  position: relative;
  float: right;
  border-radius: 5px;
  background: linear-gradient(120deg, #e5e5e5 30%, #f0f0f0 38%, #f0f0f0
  40%, #e5e5e5 48%);
  margin-top: 10px;
  background-size: 200% 100%;
  background-position: 100% 0;
  animation: load89234 2s infinite;
}

@keyframes load89234 {
  100% {
    background-position: -100% 0;
  }
}
  • .card设置卡片的宽度、高度、背景色、阴影、位置、变换、内边距和边框半径。
  • .card_load设置主加载条的宽度、高度、背景渐变、边框半径和背景大小。
  • 使用background-position和animation属性创建水平移动的加载效果。
  • .card_load_extreme_title 和 .card_load_extreme_descripion设置标题和描述加载条的宽度、高度、背景渐变、边框半径和背景大小。
  • 同样使用background-position和animation属性创建加载效果。
  • @keyframes load89234定义了一个关键帧动画,使背景位置从100%移动到-100%,实现加载条的动画效果。
相关推荐
teeeeeeemo12 分钟前
Vue数据响应式原理解析
前端·javascript·vue.js·笔记·前端框架·vue
Sahas101916 分钟前
__VUE_PROD_HYDRATION_MISMATCH_DETAILS__ is not explicitly defined.
前端·javascript·vue.js
Jinxiansen021126 分钟前
Vue 3 实战:【加强版】公司通知推送(WebSocket + token 校验 + 心跳机制)
前端·javascript·vue.js·websocket·typescript
JohnYan38 分钟前
Bun技术评估 - 05 SQL
javascript·后端·bun
前端农民晨曦41 分钟前
深入浏览器事件循环与任务队列架构
前端·javascript·面试
Spider_Man1 小时前
JavaScript对象那些坑:初学者必踩的“陷阱”与进阶秘籍
前端·javascript
我在北京coding1 小时前
Uncaught ReferenceError: process is not defined
前端·javascript·vue.js
张成AI1 小时前
A2A JS SDK 完整教程:快速入门指南
javascript·agent·a2a
子言sugar1 小时前
CSS高效开发必备小技巧集锦
css
baozj1 小时前
一次表单数据复用引发的 Bug:理解 Vue 中的 data 为何是函数
前端·javascript·vue.js