前言
今天写的是纯css写的动画,效果运行起来还不错。直接拿代码可用
HTML代码
HTML代码
<div class="animation-wrapper" style="z-index: 1">
<div class="particle particle-1"></div>
<div class="particle particle-2"></div>
<div class="particle particle-3"></div>
<div class="particle particle-4"></div>
</div>
css代码
<style scoped lang="scss">
/* Config */
$color-bg: #111;
$color-particle: #ffffff80;
$spacing: 2560px;
$time-1: 60s;
$time-2: 120s;
$time-3: 180s;
$time-4: 600s;
/* Pauls awesome mixin */
@function particles($max) {
$val: 0px 0px $color-particle;
@for $i from 1 through $max {
$val: #{$val},
random($spacing)+px random($spacing)+px $color-particle;
}
@return $val;
}
@mixin particles($max) {
box-shadow: particles($max);
}
.animation-wrapper {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.particle,
.particle:after {
background: transparent;
}
.particle:after {
position: absolute;
content: "";
top: $spacing;
}
.particle-1 {
animation: animParticle $time-1 linear infinite;
@include particles(600);
height: 1px;
width: 1px;
}
.particle-1:after {
@include particles(600);
height: 1px;
width: 1px;
}
.particle-2 {
animation: animParticle $time-2 linear infinite;
@include particles(200);
height: 2px;
width: 2px;
}
.particle-2:after {
@include particles(200);
height: 2px;
width: 2px;
}
.particle-3 {
animation: animParticle $time-3 linear infinite;
@include particles(100);
height: 3px;
width: 3px;
}
.particle-3:after {
@include particles(100);
height: 3px;
width: 3px;
}
.particle-4 {
animation: animParticle $time-4 linear infinite;
@include particles(400);
height: 1px;
width: 1px;
}
.particle-4:after {
@include particles(400);
height: 1px;
width: 1px;
}
@keyframes animParticle {
from { transform: translateY(0px); }
to { transform: translateY($spacing * -1); }
}
</style>