在本文中,我们将介绍如何使用纯CSS实现3个小球围成三角形旋转的Loading特效。这个特效可以用在网页的加载过程中,使用户等待的时间更加有趣和轻松。
实现方法
使用CSS3的@keyframes规则,通过不断改变每个元素的属性,来实现小球位移的动画效果。同时,使用了CSS的transform属性来控制元素的渐隐和移动。
实现步骤
- 创建一个HTML文件,并在文件中添加一个div容器,用于包含各种Loading特效的元素。
- 使用CSS对div容器进行样式设置。
- 根据需要,创建元素,并对其进行样式设置,如设置宽高、边框、圆角等。
- 使用CSS3的@keyframes规则,对每个元素设置不同的动画效果。
- 使用CSS的transform属性,控制元素的旋转和移动。
代码实现
以下是实现该Loading特效的HTML和CSS代码:
<div class="loading">
<div></div>
<div></div>
<div></div>
</div>
<style>
.loading,
.loading > div {
position: relative;
box-sizing: border-box;
}
.loading {
display: block;
font-size: 0;
color: #000;
}
.loading.la-dark {
color: #333;
}
.loading > div {
display: inline-block;
float: none;
background-color: currentColor;
border: 0 solid currentColor;
}
.loading {
width: 32px;
height: 32px;
}
.loading > div {
position: absolute;
top: 0;
left: 0;
width: 10px;
height: 10px;
border-radius: 100%;
}
.loading > div:nth-child(1) {
animation: ball-triangle-path-ball-one 2s 0s ease-in-out infinite;
}
.loading > div:nth-child(2) {
animation: ball-triangle-path-ball-two 2s 0s ease-in-out infinite;
}
.loading > div:nth-child(3) {
animation: ball-triangle-path-ball-tree 2s 0s ease-in-out infinite;
}
.loading.la-sm {
width: 16px;
height: 16px;
}
.loading.la-sm > div {
width: 4px;
height: 4px;
}
.loading.la-2x {
width: 64px;
height: 64px;
}
.loading.la-2x > div {
width: 20px;
height: 20px;
}
.loading.la-3x {
width: 96px;
height: 96px;
}
.loading.la-3x > div {
width: 30px;
height: 30px;
}
@keyframes ball-triangle-path-ball-one {
0% {
transform: translate(0, 220%);
}
17% {
opacity: 0.25;
}
33% {
opacity: 1;
transform: translate(110%, 0);
}
50% {
opacity: 0.25;
}
66% {
opacity: 1;
transform: translate(220%, 220%);
}
83% {
opacity: 0.25;
}
100% {
opacity: 1;
transform: translate(0, 220%);
}
}
@keyframes ball-triangle-path-ball-two {
0% {
transform: translate(110%, 0);
}
17% {
opacity: 0.25;
}
33% {
opacity: 1;
transform: translate(220%, 220%);
}
50% {
opacity: 0.25;
}
66% {
opacity: 1;
transform: translate(0, 220%);
}
83% {
opacity: 0.25;
}
100% {
opacity: 1;
transform: translate(110%, 0);
}
}
@keyframes ball-triangle-path-ball-tree {
0% {
transform: translate(220%, 220%);
}
17% {
opacity: 0.25;
}
33% {
opacity: 1;
transform: translate(0, 220%);
}
50% {
opacity: 0.25;
}
66% {
opacity: 1;
transform: translate(110%, 0);
}
83% {
opacity: 0.25;
}
100% {
opacity: 1;
transform: translate(220%, 220%);
}
}
</style>