【每日一练】78—CSS实现发光的渐变圆形文本动画效果

共 3302字,需浏览 7分钟

 ·

2022-10-15 00:57


写在前面

我们今天练习这个小项目,跟之前的圆形时钟的效果类似,我们可以先一起来看一下它的最终效果:

现在,我们再来看一下,它的实现过程,具体源码如下:
HTML代码:
<!doctype html><html><head>  <meta charset="utf-8">  <title>【每日一练】78—CSS实现发光的渐变圆形文本动画效果</title></head><body>  <div class="circle">    <ul>      <li style="--i:-4;"><span></span></li>      <li style="--i:-3;"><span>O</span></li>      <li style="--i:-2;"><span>n</span></li>      <li style="--i:-1;"><span>l</span></li>      <li style="--i:0;"><span>i</span></li>      <li style="--i:1;"><span>n</span></li>      <li style="--i:2;"><span>e</span></li>      <li style="--i:3;"><span></span></li>      <li style="--i:4;"><span>s</span></li>      <li style="--i:5;"><span>l</span></li>      <li style="--i:6;"><span>a</span></li>      <li style="--i:7;"><span>i</span></li>      <li style="--i:8;"><span>r</span></li>      <li style="--i:9;"><span>o</span></li>      <li style="--i:10;"><span>t</span></li>      <li style="--i:11;"><span>u</span></li>      <li style="--i:12;"><span>T</span></li>    </ul>  </div></body></html>
CSS代码:
*{  margin: 0;  padding: 0;  box-sizing: border-box;  font-family: consolas;}body {  display: flex;  justify-content: center;  align-items: center;  min-height: 100vh;  background: #222;}.circle {  position: relative;  width: 500px;  height: 500px;  display: flex;  justify-content: center;  align-items: center;  border-radius: 50%;  background: rgba(255,255,255,0.05);  box-shadow: 0 0 0 2px #fff5,              0 0 0 20px #333,              0 0 0 22px #fff,              0 0 50px #fff,              0 0 450px #fff;}.circle::before {  content: '';  position: absolute;  width: 2px;  height: 170px;  border-radius: 2px;  background: linear-gradient(0deg,transparent,#fff);  transform-origin: bottom;  animation: animateNiddles 20s steps(59) infinite;}.circle::after {  content: '';  position: absolute;  width: 4px;  border-radius: 2px;  height: 130px;  background: linear-gradient(0deg,transparent,#fff);  transform-origin: bottom;  animation: animateNiddles 120s linear infinite;}@keyframes animateNiddles {  0%   {    transform: translate(-50%,-50%) rotate(0deg);  }  100%   {    transform: translate(-50%,-50%) rotate(360deg);  }}ul li {  list-style: none;  position: absolute;  top: 10px;  transform-origin: 0 240px;  transform: rotate(calc(21deg * var(--i)));  font-size: 2.5em;  font-weight: bold;  text-transform: uppercase;}ul li span {  display: inline-block;  transform: rotate(calc(-21deg * var(--i)));  color: #fff;  text-shadow: 0 0 15px #fff,  0 0 35px #fff,  0 0 75px #fff,  0 0 150px #fff;}body::before {  content: '';  position: absolute;  inset: 0;  background: linear-gradient(#08ff12, #0791ff);  z-index: 10;  mix-blend-mode: multiply;  pointer-events: none;}

写在最后

以上就是我们今天的【每日一练】的全部内容,希望今天的小练习对你有用,如果你觉得有帮助的话,请点赞我,关注我,并将它分享给你身边做开发的朋友,也许能够帮助到他。

我是杨小爱,我们明天见。

学习更多技能

请点击下方公众号

浏览 51
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报