使用 CSS 实现一个简单的骨架屏(Skeleton Screen)


本文摘自PHP中文网,作者Guanhui,侵删。

前言

在加载网络数据时,为了提升用户体验,通常会使用一个转圈圈的loading动画,或者使用Skeleton Screen占位。相比与loading动画,Skeleton Screen的效果要更生动,实现起来来也很简单。利用CSS就可以实现一个简单的Skeleton Screen。(什么是骨架屏(Skeleton Screen)?)

推荐学习:CSS视频教程、CSS教程(图文)

思路

  • HTML搭建骨架

  • CSS加样式

  • CSS加动画

从搭建骨架开始

骨架结构很简单,只是随意的放几个你喜欢的块级元素就ok了。

1

2

3

4

5

6

<p class='screen-root'>

  <ul>

    <li/>

    <li/>

    <li/>

  </ul></p>

你看,就是这样简简单单。

CSS上色

我们常看到的骨架屏是这个样子的

为了方便描述,增强对比,我会先做一个鬼畜版的

首先利用css的 linear-gradient 属性画一个红中带点绿的渐变图片,并把它当作背景填充给li标签

linear-gradient()可以创建一个多种颜色线性渐变的图片,想了解更多可以看这里

1

2

li{    background-image: linear-gradient(90deg, #ff0000 25%, #41de6a 37%, #ff0000 63%);    width: 100%;    height: 0.6rem;    list-style: none;

}

实际使用中将渐变图换成正常的颜色,如:background-image: linear-gradient(90deg, #f2f2f2 25%, #e6e6e6 37%, #f2f2f2 63%)

让它动起来

剩下要做的就是让中间的绿色动起来

你可以想一下有什么办法让它动?

这里用到的是,通过拉伸背景图片,动态设置背景定位百分比,改变背景定位,从而计算得到图片相对容器的不同偏移值,以此实现了动画的效果。

阅读剩余部分

相关阅读 >>

一步步教你使用css制作一个简单美观的导航栏(代码详解)

css font-family属性怎么用

css 背景不滚动的实现方法

css如何去掉color值

css如何设置table边框的颜色

css计数器如何实现自动嵌套编号

css动画怎么匀速

css怎么设置li不要点

css继承样式有哪些

css如何让字竖着写

更多相关阅读请进入《css》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...