用CSS怎样实现骨架屏?实现思路和方法是什么?
Admin 2021-10-23 群英技术资讯 538 次浏览
用CSS怎样实现骨架屏?一些朋友可能对骨架屏不是很了解,在需要加载网络数据场景,为了提升用户体验,我们常常会看到一个转圈圈的loading动画,而骨架屏就可以实现这样的loading动画效果,而且相比loading动画,骨架屏的效果更好,实现更简单,接下来我们就来具体了解看看用CSS是怎样实现骨架屏吧。
思路
从搭建骨架开始
骨架结构很简单,只是随意的放几个你喜欢的块级元素就ok了。
<div class='screen-root'> <ul> <li/> <li/> <li/> </ul> </div>
你看,就是这样简简单单。
CSS上色
我们常看到的骨架屏是这个样子的
为了方便描述,增强对比,我会先做一个鬼畜版的
首先利用css的 linear-gradient
属性画一个红中带点绿的渐变图片,并把它当作背景填充给 li
标签
linear-gradient()可以创建一个多种颜色线性渐变的图片,想了解更多可以看这里
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%)
让它动起来
剩下要做的就是让中间的绿色动起来
你可以想一下有什么办法让它动?
这里用到的是,通过拉伸背景图片,动态设置背景定位百分比,改变背景定位,从而计算得到图片相对容器的不同偏移值,以此实现了动画的效果。
li{ background-image: linear-gradient(90deg, #ff0000 25%, #41de6a 37%, #ff0000 63%); width: 100%; height: 0.6rem; list-style: none; background-size: 400% 100%; background-position: 100% 50%; animation: skeleton-loading 1.4s ease infinite; } @keyframes skeleton-loading { 0% { background-position: 100% 50%; } 100% { background-position: 0 50%; } }
这里给 background-position
属性设置了两个值,第一个值代表水平位置相对容器的偏移,第二个代表垂直位置相对容器的偏移。
使用百分比设置 background-position
值时,它会执行一个计算实际定位值公式 (container width - image width) * (position x%) = (x offset value)
,即容器和图片的宽度差乘上设置的百分比定位值,得到的结果就是实际的偏移值,将 background-size
的宽度设置为400%的其中一个目的就是,这样就会和容器产生宽度差。
有同学可能会问,将 background-size
值设为50%,也可以和容器产生宽度差。是的,但是这样,背景图片会平铺整个容器,你会惊喜的发现,绿点变成了double。
你可以试着给background-size设置不同的值,观察它的表现,并想一下为什么会这样。
最后利用关键帧动画,设置 background-position
在x坐标的值从 100%
到 0%
@keyframes skeleton-loading { 0% { background-position: 100% 50%; } 100% { background-position: 0 50%; } }
假设容器的宽度是 100px
,那么背景图片的宽度就是 400px
,利用上边的公式,第一帧的动画中,背景图相对容器偏移的真实值是
(100px-400px)*100% = -300px
最后一帧实际偏移
(100px-400px)*0% = 0
动画的过程实际就是一个3倍容器宽的线性背景图片相对于容器的偏移从 -300px
到 0
的变化的过程。
总结
以上就是用CSS实现骨架屏的思路及方法的介绍啦,上述示例具有一定的借鉴价值,有需要的朋友可以参考,希望大家阅读完这篇文章能有所收获,想要了解更多可以继续浏览群英网络其他相关的文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
css怎么写三列自适应布局?在做前端开发的时候我们经常会使用三列布局,那么两边固定,中间自适应的三列布局要怎么写呢?下面是小编整理的多种实现方法,有需要的朋友可以看一下。
方法:1、利用background属性设置背景颜色为灰色,只需要给元素添加“background:#c0c0c0;”样式;2、利用opacity属性设置元素的透明度,只需要给元素添加“opacity:透明度值;”样式即可。
怎么使用SVG给 favicon 添加标识?下面本篇文章给大家介绍一下使用 SVG 生成带标识的 favicon的方法,希望对大家有所帮助!
CSS Text(文本)属性用于定义文本的外观,比如文本的颜色,对齐文本,装饰文本,文本颜色,行间距等。本篇文章带大家了解一下CSS 文本属性(Text),希望对大家有所帮助!
使用CSS实现播放声音有几种方法?我们知道CSS的功能是很强大的,改变网页样式、颜色、布局,实现动画等等,今天我们来了解用CSS实现播放声音的技巧,感兴趣的朋友就继续往下看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008