用户正在浏览网站网页时,为了更好的用户体验,经常会使用 加载中 文字或者动画来表示正在 加载数据 或 执行某项操作。而使用动画不仅能够吸引用户的注意力,同时也能够传达信息"系统正在工作中",需要一些时间来完成任务。本文将详细介绍如何通过 CSS 创建一个 加载中 动画效果。
首先是HTML代码,定义了一个类名container的<div>容器:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>CSS Animation</title>
<link rel="stylesheet" href="./index.css">
</head>
<body>
<div class="container">
<div class="loader" style="--r: 1">
<span style="--i: 1"></span>
<span style="--i: 2"></span>
<span style="--i: 3"></span>
<span style="--i: 4"></span>
<span style="--i: 5"></span>
<span style="--i: 6"></span>
<span style="--i: 7"></span>
<span style="--i: 8"></span>
<span style="--i: 9"></span>
<span style="--i: 10"></span>
<span style="--i: 11"></span>
<span style="--i: 12"></span>
<span style="--i: 13"></span>
<span style="--i: 14"></span>
<span style="--i: 15"></span>
<span style="--i: 16"></span>
<span style="--i: 17"></span>
<span style="--i: 18"></span>
<span style="--i: 19"></span>
<span style="--i: 20"></span>
</div>
<div class="loader" style="--r: 2">
<span style="--i: 1"></span>
<span style="--i: 2"></span>
<span style="--i: 3"></span>
<span style="--i: 4"></span>
<span style="--i: 5"></span>
<span style="--i: 6"></span>
<span style="--i: 7"></span>
<span style="--i: 8"></span>
<span style="--i: 9"></span>
<span style="--i: 10"></span>
<span style="--i: 11"></span>
<span style="--i: 12"></span>
<span style="--i: 13"></span>
<span style="--i: 14"></span>
<span style="--i: 15"></span>
<span style="--i: 16"></span>
<span style="--i: 17"></span>
<span style="--i: 18"></span>
<span style="--i: 19"></span>
<span style="--i: 20"></span>
</div>
<div class="loader" style="--r: 3">
<span style="--i: 1"></span>
<span style="--i: 2"></span>
<span style="--i: 3"></span>
<span style="--i: 4"></span>
<span style="--i: 5"></span>
<span style="--i: 6"></span>
<span style="--i: 7"></span>
<span style="--i: 8"></span>
<span style="--i: 9"></span>
<span style="--i: 10"></span>
<span style="--i: 11"></span>
<span style="--i: 12"></span>
<span style="--i: 13"></span>
<span style="--i: 14"></span>
<span style="--i: 15"></span>
<span style="--i: 16"></span>
<span style="--i: 17"></span>
<span style="--i: 18"></span>
<span style="--i: 19"></span>
<span style="--i: 20"></span>
</div>
<div class="loader" style="--r: 4">
<span style="--i: 1"></span>
<span style="--i: 2"></span>
<span style="--i: 3"></span>
<span style="--i: 4"></span>
<span style="--i: 5"></span>
<span style="--i: 6"></span>
<span style="--i: 7"></span>
<span style="--i: 8"></span>
<span style="--i: 9"></span>
<span style="--i: 10"></span>
<span style="--i: 11"></span>
<span style="--i: 12"></span>
<span style="--i: 13"></span>
<span style="--i: 14"></span>
<span style="--i: 15"></span>
<span style="--i: 16"></span>
<span style="--i: 17"></span>
<span style="--i: 18"></span>
<span style="--i: 19"></span>
<span style="--i: 20"></span>
</div>
</div>
</body>
</html>
接下来看CSS代码,重置全局样式后,给.container元素定义了水平垂直居中布局,然后使用filter样式属性来应用色相旋转(hue-rotate)滤镜,将背景色调整为90度的色相。因此,子元素的任何颜色同样会添加滤镜。
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
.container {
min-height: 100vh;
background-color: #042104;
filter: hue-rotate(90deg);
display: flex;
justify-content: center;
align-items: center;
}
.loader {
position: relative;
transform: rotate(calc(var(--r) * 45deg));
}
.loader span {
position: absolute;
top: 0;
left: -200px;
width: 200px;
height: 2px;
transform-origin: right;
transform: rotate(calc(var(--i) * 18deg));
}
.loader span::before {
content: "";
display: block;
width: 15px;
height: 15px;
background-color: #00ff0a;
border-radius: 15px;
box-shadow: 0 0 10px #00ff0a,
0 0 20px #00ff0a,
0 0 40px #00ff0a,
0 0 60px #00ff0a,
0 0 80px #00ff0a, 0 0 100px #00ff0a;
animation: animate 5s linear infinite;
animation-delay: calc(-0.5s * var(--i));
}
@keyframes animate {
0% {
transform: translateX(200px) scale(1);
opacity: 0;
}
10% {
opacity: 1;
}
80% {
opacity: 1;
}
100% {
transform: translateX(0) scale(0);
opacity: 1;
}
}
@media screen and (max-width: 576px) {
.container .loader {
scale: .6;
}
}
此外,通过animation属性和@keyframes规则,定义了名为animate的关键帧动画。该动画在5秒内线性地进行,无限循环播放。动画的每个关键帧设置了不同的变换效果,包括 平移、缩放和透明度 变化。根据时间的进展,加载器的形状和位置会发生变化,从而创造出动态的效果。
关于减少长时间等待的焦虑感,相关 加载中 动画效果的文章。
通过本篇文章的详细介绍,相信能够帮助你更好地使用CSS来创建一个loading加载中动画,从而理解掌握和应用这个效果。你可以根据自己的需求调整大小、颜色和持续时间等参数,创建符合你网页风格的加载中动画。加载中动画不仅能够提供视觉上的反馈,告诉用户系统正在工作中,还能够改善用户体验,减少长时间等待的焦虑感。
作者:掘一
链接:https://juejin.cn/post/7296404570949173298
CSS3引入了强大的动画功能,使得开发者能够在不依赖JavaScript的情况下创建丰富的视觉动效。本文将深入探讨CSS3动画的核心概念、主要特性以及如何通过关键帧动画和过渡效果实现各类动画效果。
1.1 过渡(Transition)
过渡是CSS3中最为基础的动画形式之一,它定义了一个元素在两种状态之间变化时的速度曲线和时间间隔。
/* 基本语法 */
.element {
transition: property duration timing-function delay;
}
/* 示例 */
.button {
background-color: red;
transition: background-color 0.5s ease-in-out;
}
在这个例子中,当.button的background-color属性发生变化时,将会在0.5秒内平滑过渡。
关键帧动画允许我们自定义更复杂的动画序列,包括多个中间状态。
/* 定义关键帧动画 */
@keyframes fadeInOut {
0% { opacity: 0; }
50% { opacity: 1; }
100% { opacity: 0; }
}
/* 应用动画 */
.element {
animation: fadeInOut 2s infinite;
}
上述代码定义了一个名为fadeInOut的关键帧动画,该动画让元素从透明度0渐变至1再回到0,整个动画循环持续2秒,并且无限重复。
示例1 - 图片淡入淡出滚动效果
.image-slide {
opacity: 0;
transition: opacity 0.5s;
will-change: opacity;
/* 当图片进入可视区域时触发动画 */
&.is-visible {
opacity: 1;
}
}
示例2 - 旋转动画
.rotate {
animation: rotate 2s linear infinite;
}
@keyframes rotate {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
总结起来,CSS3动画功能强大且灵活,通过过渡和关键帧动画,我们可以轻松构建丰富多样的网页动态效果,提升用户体验并增强交互性。随着对CSS3动画特性的深入理解和掌握,开发者能够更加自如地运用这些技术来创作富有创意和吸引力的Web界面。
1.什么是CSS?
2.为什么使用CSS?
3.CSS作用
动画的原理
定义
概念
浏览器渲染过程步骤
三棵树
如何更新样式
一般JS来更新样式
三种更新方式
1.JS/CSS》样式》布局》绘制》合成
全走
比如:div.remove()会触发当前消失,其它元素relayout。
2.JS/CSS》样式》绘制》合成
跳过Layout
比如:改变背景色,直接repaint+composite。
3.JS/CSS》样式》合成
跳过Layout和Paint
比如:改变transform,直接composite。
CSS动画优化
一. transform
四个常用功能
经验:
transform: translate
经验:
#demo{
left:50%;
top:50%;
transform:translate(-50%,-50%);
}
transform: scale
经验:
transform: rotate
经验:
transform: skew
经验:
transform 可以组合使用
transition 过渡
作用
语法
并不是所有的属性都能过度
二. animation
缩写语法
使用animation
如何让动画停在最后一帧
@keyframes 完整语法
本文为作者本人的原创文章,著作权归作者本人和饥人谷所有,转载务必注明来源。
*请认真填写需求信息,我们会在24小时内与您取得联系。