Sass 星空(Sass + keyframes 实现星空动画)

Sass 星空(Sass + keyframes 实现星空动画)

  • [1. 准备](#1. 准备)
  • [2. 代码](#2. 代码)
  • [3. 扩展(颜色渐变)](#3. 扩展(颜色渐变))

Sass 星空

1. 准备

如上图所示,我们将用sass来实现一个星空运动的效果。

为了实现方便,我这里直接使用 vue3 + sass 的方式实现。

当然,你不用 vue3 或者其他框架,或者直接使用 sass 都无所谓,这不是重点。重点是使用 sass 实现动画效果。

(1)创建vue3项目:

shell 复制代码
pnpm create vue@latest

按照需求输入项目名称(比如 sass-star)和选择需要下载的包。

(2)下载依赖:

shell 复制代码
cd sass-star
pnpm i

(3)下载 sass 相关依赖

shell 复制代码
pnpm i sass sass-loader

(4)运行项目

shell 复制代码
pnpm dev

(5)修改全局样式 src/assets/main.css:

css 复制代码
* {
  margin: 0;
  padding: 0;
}
#app{
  width: 100vw;
  height: 100vh;
}

2. 代码

App.vue:

javascript 复制代码
<template>
  <div class="sky">
    <div class="layer1"></div>
    <div class="layer2"></div>
    <div class="layer3"></div>
    <div class="layer4"></div>
    <div class="layer5"></div>
    <div class="title">Sass 星空</div>
  </div>
</template>

<script setup lang="ts">

</script>

<style lang="scss" scoped>
.sky {
  width: 100%;
  height: 100%;
  background-color: black;
}

.title {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  font-size: 40px;
  letter-spacing: 10px;
  font-size: 40px;
  font-weight: bold;
  // 渐变文字效果
  background: linear-gradient(#fff, #000);
  /* 关键属性:背景裁剪为文字 */
  background-clip: text;
  -webkit-background-clip: text;
  /* 文字颜色透明以显示渐变背景 */
  color: transparent;
  /* 兼容性处理 */
  -webkit-text-fill-color: transparent;
  display: inline-block;
  
}

// 生成随机位置阴影效果(其实就是某一个layer的指定数目但位置随机的分身)
@function getShadows($n) {
  $shadows: '#{random(100)}vw #{random(100)}vh #fff';

  @for $i from 2 through $n {
    $shadows: '#{$shadows}, #{random(100)}vw #{random(100)}vh #fff';
  }

  @return unquote($shadows);
}


$duration: 400s;
$count: 1000;

@for $i from 1 through 5 {
  // 每一层动画时长减半,星星数目减半
  $duration: $duration / 2;
  $count: floor($count / 2);

  .layer#{$i} {
    $size: #{$i}px;
    position: fixed;
    width: $size;
    height: $size;
    border-radius: 50%;
    left: 0;
    top: 0;
    background: #f40;
    box-shadow: getShadows($count);
    animation: moveUp $duration infinite linear;

    // 设置伪元素,形成两个屏幕高度的动画效果,从而实现无缝衔接
    &::after {
      content: '';
      position: fixed;
      left: 0;
      top: 100vh;
      border-radius: inherit;
      width: inherit;
      height: inherit;
      box-shadow: inherit;
    }
  }
}

// 动画效果
@keyframes moveUp {
  to {
    transform: translateY(-100vh);
  }
}
</style>

3. 扩展(颜色渐变)

(1)中心向外放射性渐变:

css 复制代码
background: radial-gradient(#fff, #000);

(2)使用多个颜色

css 复制代码
background: linear-gradient(to right,#e66465, #9198e5, #3baffe);

(3)修改渐变方向

css 复制代码
background: linear-gradient(to right,#e66465, #9198e5, #3baffe);

我感觉这个效果不错

相关推荐
kyriewen13 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒13 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮14 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦14 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer14 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队14 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY14 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_15 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏15 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
SkyWalking中文站15 小时前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控