1、废话不多说,先看效果

今日分享-流星雨特效代码_流星雨特效

2、实现原理

运用 background: linear-gradient 、 position 、animation、keyframes 等CSS3属性实现。

3、具体实现代码

HTML【wxml】

<view class="box">
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
  <view class="rain-s"></view>
</view>

CSS【wxss】

page {
  background: radial-gradient(ellipse at bottom, #1b2735 0%, #090a0f 100%);
  height: 100vh;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
}

.box {
  position: relative;
  width: 100%;
  height: 100%;
  transform: rotateZ(45deg);
  position: fixed;
  top: 0;
  left: 0;
}

.rain-s {
  position: absolute;
  left: 50%;
  top: 50%;
  height: 2px;
  background: linear-gradient(-45deg, #5f91ff, rgba(0, 0, 255, 0));
  border-radius: 999px;
  filter: drop-shadow(0 0 6px #699bff);
  animation: tail 3s ease-in-out infinite, start 3s ease-in-out infinite;
}

.rain-s::before {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 0;
  height: 2px;
  background: linear-gradient(-45deg, rgba(0, 0, 255, 0), #5f91ff, rgba(0, 0, 255, 0));
  transform: translateX(50%) rotateZ(45deg);
  border-radius: 100%;
  animation: shining 3s ease-in-out infinite;
}

.rain-s::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  right: 0;
  height: 2px;
  background: linear-gradient(-45deg, rgba(0, 0, 255, 0), #5f91ff, rgba(0, 0, 255, 0));
  transform: translateX(50%) rotateZ(45deg);
  border-radius: 100%;
  animation: shining 3s ease-in-out infinite;
  transform: translateX(50%) rotateZ(-45deg);
}

.rain-s:nth-child(1) {
  top: calc(50% - 81px);
  left: calc(50% - 37px);
  animation-delay: 1023ms;
}

.rain-s:nth-child(1)::before,
.rain-s:nth-child(1)::after {
  animation-delay: 1023ms;
}

.rain-s:nth-child(2) {
  top: calc(50% - 22px);
  left: calc(50% - 154px);
  animation-delay: 4673ms;
}

.rain-s:nth-child(2)::before,
.rain-s:nth-child(2)::after {
  animation-delay: 4673ms;
}

.rain-s:nth-child(3) {
  top: calc(50% - 128px);
  left: calc(50% - 1px);
  animation-delay: 5495ms;
}

.rain-s:nth-child(3)::before,
.rain-s:nth-child(3)::after {
  animation-delay: 5495ms;
}

.rain-s:nth-child(4) {
  top: calc(50% - 86px);
  left: calc(50% - 147px);
  animation-delay: 1132ms;
}

.rain-s:nth-child(4)::before,
.rain-s:nth-child(4)::after {
  animation-delay: 1132ms;
}

.rain-s:nth-child(5) {
  top: calc(50% - -1px);
  left: calc(50% - 52px);
  animation-delay: 1517ms;
}

.rain-s:nth-child(5)::before,
.rain-s:nth-child(5)::after {
  animation-delay: 1517ms;
}

.rain-s:nth-child(6) {
  top: calc(50% - 55px);
  left: calc(50% - 209px);
  animation-delay: 9108ms;
}

.rain-s:nth-child(6)::before,
.rain-s:nth-child(6)::after {
  animation-delay: 9108ms;
}

.rain-s:nth-child(7) {
  top: calc(50% - 47px);
  left: calc(50% - 154px);
  animation-delay: 2702ms;
}

.rain-s:nth-child(7)::before,
.rain-s:nth-child(7)::after {
  animation-delay: 2702ms;
}

.rain-s:nth-child(8) {
  top: calc(50% - 186px);
  left: calc(50% - 273px);
  animation-delay: 8824ms;
}

.rain-s:nth-child(8)::before,
.rain-s:nth-child(8)::after {
  animation-delay: 8824ms;
}

.rain-s:nth-child(9) {
  top: calc(50% - 53px);
  left: calc(50% - 245px);
  animation-delay: 9125ms;
}

.rain-s:nth-child(9)::before,
.rain-s:nth-child(9)::after {
  animation-delay: 9125ms;
}

.rain-s:nth-child(10) {
  top: calc(50% - 57px);
  left: calc(50% - 283px);
  animation-delay: 2233ms;
}

.rain-s:nth-child(10)::before,
.rain-s:nth-child(10)::after {
  animation-delay: 2233ms;
}

.rain-s:nth-child(11) {
  top: calc(50% - -126px);
  left: calc(50% - 144px);
  animation-delay: 6880ms;
}

.rain-s:nth-child(11)::before,
.rain-s:nth-child(11)::after {
  animation-delay: 6880ms;
}

.rain-s:nth-child(12) {
  top: calc(50% - -197px);
  left: calc(50% - 131px);
  animation-delay: 8614ms;
}

.rain-s:nth-child(12)::before,
.rain-s:nth-child(12)::after {
  animation-delay: 8614ms;
}

.rain-s:nth-child(13) {
  top: calc(50% - -57px);
  left: calc(50% - 146px);
  animation-delay: 8211ms;
}

.rain-s:nth-child(13)::before,
.rain-s:nth-child(13)::after {
  animation-delay: 8211ms;
}

.rain-s:nth-child(14) {
  top: calc(50% - 191px);
  left: calc(50% - 80px);
  animation-delay: 1686ms;
}

.rain-s:nth-child(14)::before,
.rain-s:nth-child(14)::after {
  animation-delay: 1686ms;
}

.rain-s:nth-child(15) {
  top: calc(50% - -143px);
  left: calc(50% - 279px);
  animation-delay: 6485ms;
}

.rain-s:nth-child(15)::before,
.rain-s:nth-child(15)::after {
  animation-delay: 6485ms;
}

.rain-s:nth-child(16) {
  top: calc(50% - 97px);
  left: calc(50% - 11px);
  animation-delay: 260ms;
}

.rain-s:nth-child(16)::before,
.rain-s:nth-child(16)::after {
  animation-delay: 260ms;
}

.rain-s:nth-child(17) {
  top: calc(50% - -145px);
  left: calc(50% - 43px);
  animation-delay: 9745ms;
}

.rain-s:nth-child(17)::before,
.rain-s:nth-child(17)::after {
  animation-delay: 9745ms;
}

.rain-s:nth-child(18) {
  top: calc(50% - 105px);
  left: calc(50% - 79px);
  animation-delay: 4761ms;
}

.rain-s:nth-child(18)::before,
.rain-s:nth-child(18)::after {
  animation-delay: 4761ms;
}

.rain-s:nth-child(19) {
  top: calc(50% - -71px);
  left: calc(50% - 48px);
  animation-delay: 5821ms;
}

.rain-s:nth-child(19)::before,
.rain-s:nth-child(19)::after {
  animation-delay: 5821ms;
}

.rain-s:nth-child(20) {
  top: calc(50% - -149px);
  left: calc(50% - 39px);
  animation-delay: 1116ms;
}

.rain-s:nth-child(20)::before,
.rain-s:nth-child(20)::after {
  animation-delay: 1116ms;
}

@keyframes tail {
  0% {
    width: 0;
  }

  30% {
    width: 100px;
  }

  100% {
    width: 0;
  }
}

@keyframes shining {
  0% {
    width: 0;
  }

  50% {
    width: 30px;
  }

  100% {
    width: 0;
  }
}

@keyframes start {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(300px);
  }
}

@keyframes sky {
  0% {
    transform: rotate(45deg);
  }

  100% {
    transform: rotate(405deg);
  }
}

4、实现简单,代码片段复制粘贴,即可预览效果体验效果。最后,贴一下自己的小程序,喜欢可以扫码查看更多...

今日分享-流星雨特效代码_CSS_02