用sass画个星空玩玩

先看看成品

Licecap录制动图总有点卡,将就着看看

原理

这种有远近效果星空的效果,实际上是由多层DIV重叠来制作的,只要每层Div所生成的星星的大小不同,那么在人眼看来,就有一种远小近大的效果

实现

先写个基础代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>星空 - sass版</title>
    <link rel="stylesheet" href="index.css"/>
</head>

<style>
*{
  margin: 0;
  padding: 0;
}

.main{
  width: 100%;
  height: 100vh;
  background: black;
}
<style/>

<body>
  <div class="main">
    <div class="layout1"></div>
    <div class="layout2"></div>
    <div class="layout3"></div>
    <div class="title">星空</div>
  </div>
</body>
</html>

其中的layoutxx就是星星的容器。

接下来就是如何生成星星,从成品图可以看到,现在的星星其实就是一个圆形,那实现一个圆这么简单就不用说了,重点是如何生成多个位置不同的圆,这里使用了阴影box-shadow来实现这种效果。

制作星空

先看看基础的layout是怎么样的,由于我们是使用了阴影来制作圆。所以layout的大小就是星星的大小,直接上代码。 下面的代码都是使用了sass

scss 复制代码
.layout1{
  $size:30px;
  position: fixed;
  top: 0;
  left: 0;
  width: $size;
  height: $size;
  background: red;
  border-radius: 50%;
}

这个时候应该是这样的

然后给layout设置一下阴影box-shadow:30vw 30vh #ffffff;

可以看到这个时候就在x:30vw,y:30vh的地方生成了一个白色的圆,那接下来就直接让它在随机的位置生成就可以了。

这个时候就要使用sass的函数来帮助我们生成多个圆,然后利用random函数来随机设置他们的位置

scss 复制代码
// 拿来生成星星的函数
@function generateAstral($n){
  $astrals:'#{random(100)}vw #{random(100)}vh #ffffff';

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

  @return unquote($astrals) ;
}

.layout1{
    ...
    // 生成300个圆
    box-shadow: generateAstral(300);
}

效果

这样一层星星就设置好了。接下来就是把所有的layout弄成不同的大小,然后按这种方式来生成即可。这里同样利用sass的方法来生成

scss 复制代码
@for $i from 1 through 3{
  .layout#{$i}{
    // 直接使用i来做大小 
    $size:#{$i}px;
    position: fixed;
    top: 0;
    left: 0;
    width: $size;
    height: $size;
    background: red;
    border-radius: 50%;
    box-shadow: generateAstral(300);
  }
}

弄完变成这样

看起来有模有样了,但是还差点东西。我们是要动起来的星空,所以还需要给他设置上动画效果,那这里需要注意一下,从成品图里面可以看见星空是往一个方向移动的,那当动画执行完成之后,由于div往上面移动了,就会导致页面空白了一片,要先解决一下这个,解决方案也很简单,直接在layout的下面拼接上一个一模一样的div不就可以了。

scss 复制代码
@for $i from 1 through 3{
  .layout#{$i}{
    $size:#{$i}px;
    position: fixed;
    top: 0;
    left: 0;
    width: $size;
    height: $size;
    background: red;
    border-radius: 50%;
    box-shadow: generateAstral(300);
    // 设置动画
    animation: moveUp 10s linear infinite;
    // 往下面拼接一个div,注意这个div要跟原来的一模一样
    &:after{
      content:" ";
      width: inherit;
      height: inherit;
      position: fixed;
      top: 100vh;
      left: 0;
      box-shadow: inherit;
      border-radius: inherit;
    }
  }
}

@keyframes moveUp {
  to{
    transform: translateY(-100vh);
  }
}

到这里就完了。完整代码:

scss 复制代码
*{
  margin: 0;
  padding: 0;
}

.main{
  width: 100%;
  height: 100vh;
  background: black;
}

@function generateAstral($n){
  $astrals:'#{random(100)}vw #{random(100)}vh #ffffff';

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

  @return unquote($astrals) ;
}

@for $i from 1 through 3{
  .layout#{$i}{
    $size:#{$i}px;
    position: fixed;
    top: 0;
    left: 0;
    width: $size;
    height: $size;
    background: red;
    border-radius: 50%;
    box-shadow: generateAstral(300);
    animation: moveUp 10s linear infinite;
    &:after{
      content:" ";
      width: inherit;
      height: inherit;
      position: fixed;
      top: 100vh;
      left: 0;
      box-shadow: inherit;
      border-radius: inherit;
    }
  }
}



@keyframes moveUp {
  to{
    transform: translateY(-100vh);
  }
}

.title{
  position: absolute;
  width: max-content;
  height: max-content;
  color: #ffffff;
  font-size: 36px;
  font-weight: bold;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin:auto;
}
相关推荐
TeleostNaCl2 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
charlie1145141912 小时前
CSS笔记4:CSS:列表、边框、表格、背景、鼠标与常用长度单位
css·笔记·学习·css3·教程
前端大卫3 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友3 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理5 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻5 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
mapbar_front6 小时前
在职场生存中如何做个不好惹的人
前端
牧杉-惊蛰6 小时前
纯flex布局来写瀑布流
前端·javascript·css
一袋米扛几楼987 小时前
【软件安全】什么是XSS(Cross-Site Scripting,跨站脚本)?
前端·安全·xss
向上的车轮7 小时前
Actix Web适合什么类型的Web应用?可以部署 Java 或 .NET 的应用程序?
java·前端·rust·.net