利用CSS3创建实用的加载动画效果(两种)

在之前的文章《利用css3创建炫酷的三角背景图像》中,我们介绍了使用css3创建炫酷的三角背景的方法。这次我们继续css3效果分享,看看利用利用纯css3如何实现加载动画效果,感兴趣的可以学习了解一下~

在进入网站时,因为需要显示许多图片,往往需要加载一段时间。如果这里添加一个动态的加载效果,这样就不会让等待变得枯燥。例如下图这样:

1.gif

本篇文章就来给大家分享两种使用CSS3实现的加载动画效果。这两种方法都是利用animation和@keyframes来实现,下面我们来看看实现代码:

第一种效果的实现方法:

html,body {padding: 0;height: 100%;display: table;margin: 0 auto;font-size: 52px;font-family: Monaco, Consolas, "Lucida Console", monospace;background-image: url("http://subtlepatterns.subtlepatterns.netdna-cdn.com/patterns/kindajean.png");}.loading {text-align: center;display: table-cell;vertical-align: middle;text-shadow: grey 1px 1px 1px;}.letter {float: left;width: 35px;height: 60px;position: relative;-webkit-animation: flip 2s infinite;-webkit-transform-style: preserve-3d;-webkit-transition: -webkit-transform 1s;}.letter div {width: 100%;height: 100%;position: absolute;-webkit-transform: translate(0);-webkit-backface-visibility: hidden;-webkit-animation: color 8s infinite;}.letter div.back {-webkit-transform: rotateY(180deg);}.letter:nth-child(1),.letter:nth-child(1) div {-webkit-animation-delay: 0.125s;}.letter:nth-child(2),.letter:nth-child(2) div {-webkit-animation-delay: 0.25s;}.letter:nth-child(3),.letter:nth-child(3) div {-webkit-animation-delay: 0.375s;}.letter:nth-child(4),.letter:nth-child(4) div {-webkit-animation-delay: 0.5s;}.letter:nth-child(5),.letter:nth-child(5) div {-webkit-animation-delay: 0.625s;}.letter:nth-child(6),.letter:nth-child(6) div {-webkit-animation-delay: 0.75s;}.letter:nth-child(7),.letter:nth-child(7) div {-webkit-animation-delay: 0.875s;}.letter:nth-child(8),.letter:nth-child(8) div {-webkit-animation-delay: 1s;}.letter:nth-child(9),.letter:nth-child(9) div {-webkit-animation-delay: 1.125s;}.letter:nth-child(10),.letter:nth-child(10) div {-webkit-animation-delay: 1.25s;}@-webkit-keyframes flip {0% {-webkit-transform: rotateY(0deg) translate(0);}40%,100% {-webkit-transform: rotateY(180deg) translate(0);}}@-webkit-keyframes color {0% {color: #88E488;}25% {color: #EEADB7;}50% {color: #90C9DB;}75% {color: #F3B034;}100% {color: #828282;}}
L
L
o
o
a
a
d
d
i
i
n
n
g
g
.
.
.
.
.
.

在上面代码中,先使用两个animation属性给每个字绑定两种动画flip和color,分别控制翻转动作和颜色变化;然后分别利用@keyframes规则,给两个动画设置每一帧的动作即可。

立即学习“前端免费学习笔记(深入)”;

翻转动作需要使用transform属性来控制,它可以向元素应用 2D 或 3D 转换。

效果如下:

1.gif

下面的效果也是同一种实现思想,只是在细微处有点改变。

第二种效果的实现方法:

html,body {padding: 0;height: 100%;display: table;margin: 0 auto;font-size: 52px;font-family: Monaco, Consolas, "Lucida Console", monospace;background: #F5F5F5;}.loading {top: 50%;left: 50%;width: 350px;height: 60px;font-size: 52px;position: absolute;text-align: center;margin-top: -30px;margin-left: -175px;text-shadow: #808080 1px 1px 1px;font-family: Monaco, Consolas, "Lucida Console", monospace;}.letter {float: left;width: 35px;height: 60px;position: relative;animation: flip 2s infinite;transform-style: preserve-3d;transition: transform 1s;}.letter div {color: #4B6;width: 100%;height: 100%;position: absolute;transform: translate(0);backface-visibility: hidden;animation: color 16s infinite;}.letter div.back {transform: rotateY(180deg);}.letter:nth-child(1),.letter:nth-child(1) div {animation-delay: 0.125s;}.letter:nth-child(2),.letter:nth-child(2) div {animation-delay: 0.25s;}.letter:nth-child(3),.letter:nth-child(3) div {animation-delay: 0.375s;}.letter:nth-child(4),.letter:nth-child(4) div {animation-delay: 0.5s;}.letter:nth-child(5),.letter:nth-child(5) div {animation-delay: 0.625s;}.letter:nth-child(6),.letter:nth-child(6) div {animation-delay: 0.75s;}.letter:nth-child(7),.letter:nth-child(7) div {animation-delay: 0.875s;}.letter:nth-child(8),.letter:nth-child(8) div {animation-delay: 1s;}.letter:nth-child(9),.letter:nth-child(9) div {animation-delay: 1.125s;}.letter:nth-child(10),.letter:nth-child(10) div {animation-delay: 1.25s;}@keyframes flip {0% {transform: rotateY(0deg) translate(0);}40%,100% {transform: rotateY(180deg) translate(0);}}@keyframes color {1.5% {color: #6AD;}3%,12.5% {color: #F80;}14% {color: #4B6;}15.5%,25% {color: #F68;}26.5% {color: #C83;}28%,37.5% {color: #96C;}39% {color: #C83;}40.5%,50% {color: #E44;}51.5% {color: #F80;}53%,62.5% {color: #4B6;}64% {color: #F68;}65.5%,75% {color: #C83;}76.5% {color: #96C;}78%,87.5% {color: #6AD;}89% {color: #F80;}90.5%,100%,0% {color: #4B6;}}
L
L
o
o
a
a
d
d
i
i
n
n
g
g
.
.
.
.
.
.

效果如下:

2.gif

下面介绍3个关键属性animation、@keyframes和transform:

CSS3 animation(动画) 属性

语法:animation: name duration timing-function delay iteration-count direction fill-mode play-state;

animation-name:指定要绑定到选择器的关键帧的名称animation-duration:动画指定需要多少秒或毫秒完成animation-timing-function:设置动画将如何完成一个周期animation-delay:设置动画在启动前的延迟间隔。animation-iteration-count:定义动画的播放次数。animation-direction:指定是否应该轮流反向播放动画。animation-fill-mode:规定当动画不播放时(当动画完成时,或当动画有一个延迟未开始播放时),要应用到元素的样式。animation-play-state:指定动画是否正在运行或已暂停。

@keyframes 规则

使用@keyframes规则可以创建动画。创建动画是通过逐步改变从一个CSS样式设定到另一个。简单来说:@keyframes就是用来设置动画每一帧动作的。

@keyframes需要和animation 属性一起使用才能实现动画:

@keyframe规则由关键字“@keyframe”组成,后面接着是给出动画名称的标识符(将使用animation-name引用),随后是通过一组样式规则(用大括号分隔)。然后,通过使用标识符作为animation-name属性的值,将动画应用于元素。例如:

/* 定义动画*/@keyframes 动画名称{    /* 样式规则*/}/* 将它应用于元素 */.element {    animation-name: 动画名称(在@keyframes中已经声明好的);    /* 或使用动画简写属性*/    animation: 动画名称 1s ...}

CSS3 transform 属性

transform 属性向元素应用 2D 或 3D 转换。该属性允许我们对元素进行旋转、缩放、移动或倾斜。

语法:transform: none|transform-functions;

none定义不进行转换。matrix(n,n,n,n,n,n)定义 2D 转换,使用六个值的矩阵。matrix3d(n,n,n,n,n,n,n,n,n,n,n,n,n,n,n,n)定义 3D 转换,使用 16 个值的 4x4 矩阵。translate(x,y)定义 2D 转换。translate3d(x,y,z)定义 3D 转换。translateX(x)定义转换,只是用 X 轴的值。translateY(y)定义转换,只是用 Y 轴的值。translateZ(z)定义 3D 转换,只是用 Z 轴的值。scale(x,y)定义 2D 缩放转换。scale3d(x,y,z)定义 3D 缩放转换。scaleX(x)通过设置 X 轴的值来定义缩放转换。scaleY(y)通过设置 Y 轴的值来定义缩放转换。scaleZ(z)通过设置 Z 轴的值来定义 3D 缩放转换。rotate(angle)定义 2D 旋转,在参数中规定角度。rotate3d(x,y,z,angle)定义 3D 旋转。rotateX(angle)定义沿着 X 轴的 3D 旋转。rotateY(angle)定义沿着 Y 轴的 3D 旋转。rotateZ(angle)定义沿着 Z 轴的 3D 旋转。skew(x-angle,y-angle)定义沿着 X 和 Y 轴的 2D 倾斜转换。skewX(angle)定义沿着 X 轴的 2D 倾斜转换。skewY(angle)定义沿着 Y 轴的 2D 倾斜转换。perspective(n)为 3D 转换元素定义透视视图。

PHP中文网平台有非常多的视频教学资源,欢迎大家学习《css视频教程》!

以上就是利用CSS3创建实用的加载动画效果(两种)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1621427.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 07:29:58
下一篇 2025年12月10日 15:30:46

相关推荐

  • 手把手教你使用css3给文字添加阴影效果(代码详解)

    之前的文章《CSS篇:如何将页面背景设置渐变效果(代码详解)》中,给大家介绍了怎样使用css设置背景色渐变。下面本篇文章给大家介绍怎样使用css3给文字添加阴影效果呢,我们一起看看怎么做。 用css3给文字添加阴影效果代码示例 文字阴影 h1{text-shadow: 7px 10px 6px #F…

    2025年12月24日 好文分享
    200
  • 一招搞定css不规则边框

    大家可能都习惯了使用box-shadow来设置盒阴影,但顾名思义,盒阴影一般阴影的投影是一个方形,如果我们遇到其他情况,想要做阴影效果应该怎么实现呢? 之前做过很多特殊的布局,比如在这两篇文章 CSS 实现优惠券的技巧 、CSS 实现支持渐变的提示框(tooltips),如下 但是一直有一个痛点就是…

    2025年12月24日 好文分享
    000
  • 手把手教你怎么使用CSS3实现动画效果(代码分享)

    之前的文章《H5篇:页面中实现动画的几种方式?(附代码)》中,带大家了解页面中实现动画的几种方式。下面本篇文章给大家介绍怎么使用CSS3来实现一个简单漂亮的动画效果,我们一起看看 复习下 css3 的动画, 都快不会写了,那会儿挺喜欢 flash 的,可惜了时代在前进。写这里就当是文档看吧 浏览器支…

    2025年12月24日
    000
  • 教你怎么使用css3给图片添加渐变效果(代码详解)

    之前的文章《手把手教你怎么使用CSS3实现动画效果(代码分享)》中,给大家介绍一下怎么使用css3动画效果设置经验。下面本篇文章给大家介绍怎么使用css3给图片添加渐变效果,伙伴们来看看一下。 初次接触css3渐变是在很早以前了,觉得这个东西很有意思哈,跟玩 PS 似的,可以做出很多华丽的东西。 浏…

    2025年12月24日 好文分享
    000
  • 手把手教你使用CSS3制作一个简单页面的布局(代码详解)

    之前的文章《深入解析微信小程序页面中实现的保存图片(附代码)》中,给大家了解一下微信小程序页面中实现的保存图片。下面本篇文章给大家介绍怎么使用CSS3制作一个简单页面的布局,感兴趣的小伙伴们可以参考一下。 兼容性 2009 年,W3C提出了一种新的方案—-Flex布局,可以简便、完整、响…

    2025年12月24日 好文分享
    000
  • css如何实现自适应

    在css中,可以使用calc()函数来实现自适应,只需要在元素中添加“元素:calc(100%-像素大小);”即可。calc()函数是css3新增的一个功能,通过计算来指定元素的长度,因此不用担心添加边距或者边框带来的问题。 本教程操作环境:windows7系统、CSS3&&HTML…

    2025年12月24日
    000
  • css3动画不循环怎么办

    css3动画不循环可以使用animation-iteration-count属性定义动画的播放次数。只需要在动画中添加“animation-iteration-count:infinite;”即可实现无限次循环。 本教程操作环境:windows7系统、CSS3&&HTML5版、Del…

    2025年12月24日
    000
  • css3如何绘制半圆

    css3绘制半圆的方法:1、利用border-radius属性实现,只需要将相邻两个角的值设置为宽/高度的一半,另两个角设置为0即可。2、利用css3的clip属性和rect()函数来实现。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 方法1…

    2025年12月24日
    000
  • css3哪个是设置动画播放次数

    在css中,可以使用animation-iteration-count属性设置动画播放次数,只需要给元素设置“animation-iteration-count: infinite”样式即可。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 an…

    2025年12月24日
    000
  • css3如何实现图片平移

    css3中,可利用transform属性实现图片平移,当值设置为“translate(x,y)”可实现图片在x轴和y轴方向同时平移,值为“translate X(x)”可在x轴方向平移,值为“translateY(y)”可在y轴方向平移。 本教程操作环境:windows7系统、CSS3&&a…

    2025年12月24日
    000
  • css3跟css区别是什么

    css3跟css区别是:1、CSS3是CSS技术的升级版本,CSS是用来表现HTML或XML等文件样式的计算机语言;2、CSS3主要包括盒子模型、列表模块等模块,CSS可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。 本教程操作环境:windows7系统、CSS3&&…

    2025年12月24日
    000
  • css3有什么用

    CSS3是CSS技术的升级版本,是朝着模块化发展的版本。以前版本的规范作为一个模块比较庞大,且比较复杂,这一版本把它分解为一些小的模块,加入了更多新的模块。 本教程操作环境:windows7系统、CSS3版、Dell G3电脑。 CSS是层叠样式表(Cascading StyleSheet)的缩写。…

    2025年12月24日
    000
  • 巧用CSS steps()函数实现随机翻牌效果!

    翻牌是大家很熟悉的一个互动效果,通常在抽奖活动中出现。那么不借助 JavaScript 是否能够实现随机翻牌效果?翻牌效果肯定是没有问题,CSS 没有随机函数,今天就来分享一个另类的交互实现思路。 CSS 没有内置的“随机”函数,没有像 Javascript 中的 Math.random() 函数,…

    2025年12月24日
    000
  • 什么是CSS motion path模块?如何制作运动路径动画?

    什么是css motion path模块?本篇文章和大家一起详细了解下css motion path模块,谈谈它的用法,介绍一下使用该模块如何制作简单和复杂的路径动画。 CSS 中有一个非常有意思的模块 — CSS Motion Path Module Level 1,翻译过来也就是运动…

    2025年12月24日 好文分享
    000
  • 你值得了解的一种CSS获取图片主题色的小技巧(分享)

    本篇文章给大家分享一种利用 css 获取图片主题色的小技巧。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 背景 起因是微信技术群里有个同学发问,有什么方法能够获取图片的主色呢?有一张图片,获取他的主色调: 利用获取到的这个颜色值,来实现类似这样的功能 — 容器中有一张…

    2025年12月24日 好文分享
    000
  • css3怎么将滚动条隐藏

    css3将滚动条隐藏的方法是,自定义滚动条的伪对象选择器【::-webkit-scrollbar】,例如【.element::-webkit-scrollbar { width: 0 !important }】。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 在…

    2025年12月24日
    000
  • 一起看看CSS filter中的那些神奇用途

    本篇文章带大家了解一下css filter 有哪些神奇用途。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 背景 基本概念 CSS filter 属性将模糊或颜色偏移等图形效果应用于元素形成滤镜,滤镜通常用于调整图像,背景和边框的渲染。它的值可以为 filter 函数 或使用 ur…

    2025年12月24日 好文分享
    000
  • 纯CSS3实现3d立体文字效果(源码分析)

    本篇文章带大家了解一下3d文字效果的实现原理,没有考虑代码的复用性和可移植性,有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 1.单单纯纯的效果一 为了简化操作,我们使用和上一篇文章《纯CSS3文字效果推荐》一样的文档结构,后面的效果大差小不差,也就不再列出。 前端开发whqet …

    2025年12月24日 好文分享
    000
  • css3如何设置背景图片

    css3设置背景图片的方法是添加属性【background-image: url(css.jpg)】。background-image属性用来设置一个元素的背景图像,url中填写图像的url地址。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 如果我们要添加一张…

    2025年12月24日
    000
  • 纯CSS实现心形加载动画(附源码)

    本篇文章给大家介绍一下纯css实现心形加载动画的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 废话不多说上代码,代码很简答,研究一下就明白了,有不明白的可以问我。 .heart-loading { margin-top: 120px; width: 200px; heigh…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信