发布网友 发布时间:2022-04-28 13:40
共6个回答
懂视网 时间:2022-04-28 18:02
实现页面加载过程需要通过CSS3中的animation动画以及transform属性中的缩放两个效果可以做出页面加载的效果,接下来在文章中将为大家详细介绍【推荐课程:CSS3教程】
对于页面加载的动画我们可以做成不同形状的效果,今天要分享的案例是将动画做成圆形的形状来加载页面,在使用动画时要注意浏览器兼容问题
知识点详解
(1)animation:设置动画属性
animation-name :设置需要绑定到选择器的 keyframe 名称。本例绑定的是load
animation-duration :完成动画所需花费的时间,以秒或毫秒为单位。
animation-timing-function:动画的速度曲线。
animation-delay:在动画开始之前的延迟。
animation-iteration-count:动画应该播放的次数。
animation-direction:是否应该轮流反向播放动画。
例:设置动画名为load,完成动画所需时间为1.4s,以低速开始和结束,无限循环播放
animation: load 1.4s infinite ease-in-out;
(2)animation-fill-mode 属性
none :不改变默认行为。
forwards:当动画完成后,保持最后一个属性值(在最后一个关键帧中定义)。
backwards:在 animation-delay 所指定的一段时间内,在动画显示之前,应用开始属性值(在第一个关键帧中定义)。
both: 向前和向后填充模式都被应用。
(3)transform :scale(x,y) 2D 缩放转换。
完整代码
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Document</title> <style> .load { margin:300px auto; width: 150px; text-align: center; } .load div{ width: 30px; height: 30px; background-color:rgb(118,224,250); border-radius: 100%; display: inline-block; -webkit-animation: load 1.4s infinite ease-in-out; -webkit-animation-fill-mode: both; } .load .circle1 { -webkit-animation-delay: -0.32s; } .load .circle2 { -webkit-animation-delay: -0.16s; } @-webkit-keyframes load { 0%, 80%, 100% { -webkit-transform: scale(0.0) } 40% { -webkit-transform: scale(1.0) } } </style> </head> <body> <div class="load"> <div class="circle1"></div> <div class="circle2"></div> <div class="circle3"></div> </body> </html>
效果图
动态效果图
总结:
热心网友 时间:2022-04-28 15:10
要使 css 中的背景图片在页面加载时全部下载完成,可以使用CSS实现。示例代码如下:
这个概念就是写一个CSS样式设置一批背景图片,然后将其隐藏,这样你就看不到那些图片了。那些背景图片就是你想预载的图片。
热心网友 时间:2022-04-28 16:28
最主要的是图片的到校控制好。至于说小图片平铺,虽然加载的时间少了。但请求数太多热心网友 时间:2022-04-28 18:02
有个奔方法,就是你把图片单独拿出来放在head里面,也就是所谓的预加载,至于具体的做法你上网搜搜吧,我印象中最简单的做法就是在head里面做个<img src>就可以了。热心网友 时间:2022-04-28 19:54
尽量用小背景图片重复,还有适当用些小图标热心网友 时间:2022-04-28 22:02
呵呵 那个不是代码做的,是要看网速的。如果真有的话我也学习学习