如何使用CSS实现变色旋转动画的动态效果

这篇文章给大家介绍的内容是关于如何使用css实现变色旋转动画的动态效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

2454854153-5b4d2dd0585f8_articlex.gif

代码解读

定义 dom,容器中包含 9 个元素:

居中显示:

body {    margin: 0;    height: 100vh;    display: flex;    align-items: center;    justify-content: center;    background-color: black;}

定义容器尺寸:

立即学习“前端免费学习笔记(深入)”;

.container {    width: 30em;    height: 30em;    font-size: 12px;}

设置容器中线条的样式:

.container {    color: lime;}.container span {    position: absolute;    width: 5em;    height: 5em;    border-style: solid;    border-width: 1em 1em 0 0;    border-color: currentColor transparent;    border-radius: 50%;}

让线条在容器中居中显示:

.container {    display: flex;    align-items: center;    justify-content: center;}

定义变量,使线条从中心向外侧逐渐延伸:

.container span {    --diameter: calc(5em + (var(--n) - 1) * 3em);    width: var(--diameter);    height: var(--diameter);}.container span:nth-child(1) {    --n: 1;}.container span:nth-child(2) {    --n: 2;}.container span:nth-child(3) {    --n: 3;}.container span:nth-child(4) {    --n: 4;}.container span:nth-child(5) {    --n: 5;}.container span:nth-child(6) {    --n: 6;}.container span:nth-child(7) {    --n: 7;}.container span:nth-child(8) {    --n: 8;}.container span:nth-child(9) {    --n: 9;}

设置让线条旋转的动画效果:

.container span {    animation: rotating linear infinite;    animation-duration: calc(5s / (9 - var(--n) + 1));}@keyframes rotating {    to {        transform: rotate(1turn);    }}

定义改变颜色的动画效果,以色相环一周 360 度为 100%,–percent 变量是指位于这个 100% 的哪个位置:

@keyframes change-color {    0%, 100% {        --percent: 0;    }    10% {        --percent: 10;    }    20% {        --percent: 20;    }    30% {        --percent: 30;    }    40% {        --percent: 40;    }    50% {        --percent: 50;    }    60% {        --percent: 60;    }    70% {        --percent: 70;    }    80% {        --percent: 80;    }    90% {        --percent: 90;    }}

最后,把改变颜色的动画效果应用到容器上:

.container {    --deg: calc(var(--percent) / 100 * 360deg);    color: hsl(var(--deg), 100%, 50%);    animation: change-color 5s linear infinite;}

大功告成!

相关文章推荐:

如何用CSS和D3实现宇宙飞船的动态效果

如何使用CSS和D3实现无尽六边形空间的效果

以上就是如何使用CSS实现变色旋转动画的动态效果的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1610918.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 01:51:14
下一篇 2025年12月24日 01:51:22

相关推荐

  • CSS样式有哪几种?css样式表的三种方式总结(附代码)

    css样式有哪几种类型?css 样式代码插入的形式来看基本可以分为以下三种:内联式、嵌入式和外部式三种,这三种样式是有优先级的,他们的优先级是:内联式 > 嵌入式 > 外部式,下面我们就来看看css三种样式类型的具体内容及代码。 注意:嵌入式>外部式有一个前提:嵌入式css样式的位…

    2025年12月24日
    000
  • css中单位的使用:选择px还是rem

    这篇文章给大家介绍的文章内容是关于css中单位的使用:选择px还是rem,有很好的参考价值,希望可以帮助到有需要的朋友。 css中的单位很多,%、px、em、rem,以及比较新的vw、vh等。每个单位都有特定的用途,比如当需要设置一个矩形的宽高比为16:9,并且随屏幕宽度自适应时,除了用%,其他单位…

    2025年12月24日
    000
  • 什么是CSS BEM命名规范?BEM命名规范的总结(详细)

    bem 是block(块)、element(元素)和modifier(修饰符)的简写,它是一个很好用的命名约定。能够让你的前端代码变得更加容易理解和严密,接下来我们就来看一看bem命名规范具体是怎样的。 1 什么是 BEM 命名规范 Bem 是块(block)、元素(element)、修饰符(mod…

    好文分享 2025年12月24日
    000
  • 浅析CSS中background背景的用法

    这篇文章给大家介绍的文章内容是关于浅析css中background背景的用法,有很好的参考价值,希望可以帮助到有需要的朋友。 定义和用法 基本属性:color, image, position, repeat 背景颜色 background-color 值为颜色值或transparent二者选其一,…

    好文分享 2025年12月24日
    000
  • 如何使用CSS和D3实现无尽六边形空间的效果

    这篇文章给大家介绍的文章内容是关于如何使用css和d3实现无尽六边形空间的效果,有很好的参考价值,希望可以帮助到有需要的朋友。 效果预览 代码解读 定义 dom,容器中包含 1 个内含 5 个 的 : 居中显示: body { margin: 0; height: 100vh; display: f…

    2025年12月24日
    000
  • 如何使用纯CSS实现一颗土星的效果

    这篇文章给大家介绍的文章内容是关于如何使用纯css实现一颗土星的效果,有很好的参考价值,希望可以帮助到有需要的朋友。 效果预览 代码解读 定义 dom,容器本身表示土星星球,其中的 ring 元素表示土星环: 居中显示: body { margin: 0; height: 100vh; displa…

    2025年12月24日
    000
  • 视频演示:如何用CSS 创作一颗逼真的土星 ?(附代码)

    效果预览 按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comehope/pen/EpbaQX 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。 请用 chrome, safari, edge 打开观看。 立即学习“…

    2025年12月24日
    000
  • 实例讲解如何用CSS语言创作一根闪电连接线

    效果预览 按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。 https://codepen.io/comehope/pen/RBjdzZ 可交互视频 此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。 请用 chrome, safari, edge 打开观看。 立即学习“…

    2025年12月24日
    000
  • css如何自定义滚动条(代码)

    本篇文章给大家分享的是关于css如何自定义滚动条(代码),内容很不错,有需要的朋友可以参考一下,希望可以帮助到大家。 html↓ css↓ .test { display: inline-block; margin: 60px 40%; width: 280px; padding: 5px 4px;…

    2025年12月24日
    000
  • css和js如何实现响应式导航菜单

    这篇文章分享给大家的内容是关于css和js如何实现响应式导航菜单,内容很有参考价值,希望可以帮到有需要的小伙伴。 1.响应式导航菜单 当视口大于640px的时候,导航条会显示在外,当视口小于768px的时候,导航菜单需要隐藏起来!代码如下: 响应式 首页 产品 购买 服务 联系 var btn=do…

    好文分享 2025年12月24日
    000
  • CSS实现响应式布局的方法

    这篇文章分享给大家的内容是关于css实现响应式布局的方法,内容很有参考价值,希望可以帮到有需要的小伙伴。 用CSS实现响应式布局 响应式布局感觉很高大上,很难,但实际上只用CSS也能实现响应式布局要用的就是CSS中的没接查询,下面就介绍一下怎么运用: 使用@media 的三种方法 1.直接在CSS文…

    2025年12月24日
    000
  • 关于css响应式的实现代码及效果

    这篇文章分享给大家的内容是关于css响应式的实现代码及效果,内容很有参考价值,希望可以帮到有需要的小伙伴。 1.CSS 来实现响应式 CSS实现响应式网站的布局要用到的就是CSS中的媒体查询接下来来简单介绍一下: @media 类型 and (条件1) and (条件二){css样式} 我们只需用到…

    2025年12月24日
    000
  • css关于浏览器兼容问题的解析

    这篇文章分享给大家的内容是关于css关于浏览器兼容问题的解析,内容很有参考价值,希望可以帮到有需要的小伙伴。 一、火狐1. 失效hack:采用jquery UI:datepicker插件。(1)下载插件,放置在项目文件夹中;(2)在所需页面引入,如: 此script与页面所需的对应的js位置不分先后…

    好文分享 2025年12月24日
    000
  • 如何理解BFC-块格式化上下文(图文)

    本篇文章分享给大家的内容是关于如何理解bfc-块格式化上下文(图文),内容很详细,接下来我们就来看看具体的内容,希望可以帮助到大家。 BFC概念 BFC(block formatting context)块格式化上下文, 是Web页面块级元素布局及浮动元素彼此交互的区域。BFC是一个独立的布局环境,…

    2025年12月24日 好文分享
    000
  • 如何用纯CSS实现动态行驶的火车

    这篇文章给大家介绍的文章内容是关于如何用纯css实现正在行驶中的火车,有很好的参考价值,希望可以帮助到有需要的朋友。 效果预览 代码解读 定义 dom,容器中包含 2 个元素,train 代表火车,track 代表铁轨,其中包含的 3 个 代表 3 根枕木。 居中显示: body{ margin: …

    2025年12月24日
    000
  • 如何使用CSS实现单元素点阵loader的效果

    这篇文章主要介绍了关于如何使用css实现单元素点阵loader的效果,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-daily-challe…

    2025年12月24日
    000
  • 如何使用纯CSS实现一台咖啡机的效果

    这篇文章主要介绍了关于如何使用纯css实现一台咖啡机的效果,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-daily-challenges …

    2025年12月24日
    000
  • 如何用纯CSS实现卡通鹦鹉的效果

    这篇文章主要介绍了关于如何用纯css实现卡通鹦鹉的效果,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-daily-challenges 代码…

    2025年12月24日
    000
  • 如何用纯CSS实现一副国际象棋

    这篇文章主要介绍了关于如何用纯css实现一副国际象棋 ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-daily-challenges 代码…

    2025年12月24日
    000
  • 教你如何用CSS来追踪用户

    我们可以用它来做什么 我们可以收集关于用户的一些基本信息,例如 屏幕分辨率(当浏览器最大化时)以及用户使用的什么浏览器(引擎) 此外,我们可以监测用户是否点击某个链接或鼠标悬停在某个元素上,用来 追踪用户悬停的链接,甚至可以 追踪用户如何移动鼠标(在页面使用不可见的字段),然而,使用目前我的方法只能…

    好文分享 2025年12月24日
    000

发表回复

登录后才能评论
关注微信