有趣的css - 多弧形加载动画

news2025/1/10 16:51:33

大家好,我是 Just,这里是「设计师工作日常」,今天分享的是用纯css实现多双弧线加载动画。

《有趣的css》系列最新实例通过公众号「设计师工作日常」发布。


目录

  • 整体效果
  • 核心代码
    • html 代码
    • css 部分代码
  • 完整代码如下
    • html 页面
    • css 样式
    • 页面渲染效果

整体效果

知识点:
①熟悉 :before:after 伪选择器的使用
②熟悉 animation 动画属性
③通过 border 来绘制双弧线

思路:先写出主体双弧线,然后通过 :before:after 来添加新的双弧线,然后设置不同的 animation 属性来让双弧线动起来。


核心代码部分,简要说明了写法思路;完整代码在最后,可直接复制到本地运行。

核心代码

html 代码

<div class="loading42"></div>

div 标签作为主体双弧线。

css 部分代码

.loading42{
  width:40px;
  height:40px;
  border:6px solid rgba(0,0,0,0);
  border-top-color: #b12a5b;
  border-bottom-color: #b12a5b;
  border-radius:50%;
  position: relative;
  animation: eff42 1.4s linear infinite;  /*设置主体动画参数*/
}
.loading42:after{
  content: '';
  width:60px;
  height:60px;
  border:6px solid rgba(0,0,0,0);
  border-top-color: #ff8177;
  border-bottom-color: #ff8177;
  border-radius:50%;
  position: absolute;
  top: -16px;
  left: -16px;
  animation: inherit;
  animation-duration: 0.7s;  /*设置动画持续时间*/
  animation-direction: reverse;  /*设置动画反向*/
}
.loading42:before{
  content: '';
  width:20px;
  height:20px;
  border:6px solid rgba(0,0,0,0);
  border-top-color: #ff8177;
  border-bottom-color: #ff8177;
  border-radius:50%;
  position: absolute;
  top: 4px;
  left: 4px;
  animation: inherit;
  animation-duration: 0.7s;  /*设置动画持续时间*/
  animation-direction: reverse;  /*设置动画反向*/
}
@keyframes eff42{
  to{
    transform: rotate(360deg);
  }
}

1、页面中 div 作为主体,通过 border 属性绘制出主体双弧线,并且给它设置 animation 动画属性相关参数

2、然后基于主体双弧线通过 :before:after 新增两个新的双弧线,设置不同的宽度、高度以及边框颜色,通过定位让三个双弧线居中分布

3、然后给两个伪选择器 :before:after 设置动画时长( animation-duration 属性 )以及动画反向( animation-direction 属性 )。

完整代码如下

html 页面

<!DOCTYPE html>
<html lang="zh">
    <head>
        <meta charset="utf-8">
        <link rel="stylesheet" href="style.css">
        <title>多弧形加载动画</title>
    </head>
    <body>
        <div class="app">
            <div class="loading42"></div>
        </div>
    </body>
</html>

css 样式

/** style.css **/
.app{
  width: 100%;
  height: 100vh;
  background-color: #ffffff;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.loading42{
  width:40px;
  height:40px;
  border:6px solid rgba(0,0,0,0);
  border-top-color: #b12a5b;
  border-bottom-color: #b12a5b;
  border-radius:50%;
  position: relative;
  animation: eff42 1.4s linear infinite;
}
.loading42:after{
  content: '';
  width:60px;
  height:60px;
  border:6px solid rgba(0,0,0,0);
  border-top-color: #ff8177;
  border-bottom-color: #ff8177;
  border-radius:50%;
  position: absolute;
  top: -16px;
  left: -16px;
  animation: inherit;
  animation-duration: 0.7s;
  animation-direction: reverse;
}
.loading42:before{
  content: '';
  width:20px;
  height:20px;
  border:6px solid rgba(0,0,0,0);
  border-top-color: #ff8177;
  border-bottom-color: #ff8177;
  border-radius:50%;
  position: absolute;
  top: 4px;
  left: 4px;
  animation: inherit;
  animation-duration: 0.7s;
  animation-direction: reverse;
}
@keyframes eff42{
  to{
    transform: rotate(360deg);
  }
}

页面渲染效果

以上就是所有代码,以及简单的思路,希望对你有一些帮助或者启发。


[1] 原文阅读


CSS 是一种很酷很有趣的计算机语言,在这里跟大家分享一些 CSS 实例 Demo,为学习者获取灵感和思路提供一点帮助,希望你们喜欢。

我是 Just,这里是「设计师工作日常」,求点赞求关注!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1550562.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL数据库基础--约束

约束 约束是作用于表中字段上的规则&#xff0c;用于限制在表中的数据 目的&#xff1a;保证数据库中数据的正确&#xff0c;有效性和完成性。 分类&#xff1a; 注意&#xff1a;约束是作用于表中字段上的&#xff0c;可以在创建表/修改表的时候哦添加约束 外键约束 外键用…

心理治疗聊天机器人的调查

摘要 这项调查旨在调查、分析和比较现有聊天机器人在心理治疗中的可行性和缺陷。调查指出了未来心理治疗聊天机器人所需的一系列任务。我们在公共数据库中检索了约1200篇相关文献&#xff0c;并选择了五种典型的和最先进的心理治疗聊天机器人。大多数最先进的心理治疗聊天机器人…

AndroidStudio中一些实用插件

1.RainbowBrackets插件为圆括号、方括号和花括号内的代码添加了漂亮的彩虹色 2.CodeGlance类似于Sublime或Xcode&#xff0c;CodeGlance插件在编辑器中嵌入了代码迷你图。滚动条也有所增大。在CodeGlance预览文件的代码模式下&#xff0c;用户可以快速导航到目标处。 3.ADBWifi…

机器人是怎么计时的(通用定时器 - 时基单元)

目录 一&#xff0c;引言 二&#xff0c;机器人的“大脑” 三&#xff0c;时基单元介绍 1&#xff0c;定时器框图 2&#xff0c;时基单元 &#xff08;1&#xff09;预分频器 &#xff08;2&#xff09;CNT计数器 &#xff08;3&#xff09;自动重装载寄存器 四&#…

如何在vue中使用echarts,与jquery中有啥不同。

一、vue中使用echarts的步骤 在 Vue 中使用 ECharts 可以按照以下步骤进行&#xff1a; 安装 ECharts&#xff1a;使用 npm 或 yarn 安装 ECharts&#xff1a; npm install echarts 在 Vue 组件中引入 ECharts&#xff1a; import echarts from echarts 在 Vue 组件的 mou…

BUUCTF-Misc15

[SWPU2019]我有一只马里奥1 1.打开附件 是一个可执行文件 2.执行 双击可执行文件生成一个1.txt的文件 文件提示ntfs,需要一个工具ntfsStreamsEditor 3.ntfsStreamsEditor “ntfsStreamsEditor” 是一个用于管理 Windows 操作系统中 NTFS&#xff08;新技术文件系统&#xff…

node的安装

官网下载&#xff08;建议使用预编译包安装&#xff09; 地址&#xff08;https://nodejs.org/en/download/prebuilt-binaries&#xff09; 解压包&#xff0c;并将 bin下面的 node npm npx加入到环境变量中或者建立软连接 ln -s 安装位置/bin/node PATH下面的路径 npm配置…

Vivado工程收敛之报告分析大全

目录 一、前言 二、分析报告 2.1 时钟分析 2.1.1 时钟报告 2.1.2 时钟网络报告 2.1.3 时钟利用率报告 2.1.4 跨时钟域报告 2.2 时序分析 2.3 约束分析 2.4 资源分析 2.5 逻辑级数分析 2.6 扇出分析 2.7 进位链分析 2.8 控制集分析 2.9 复杂度分析 2.10 pipelin…

运筹学基础(一)求解线性规划的单纯形法详解

文章目录 前言线性规划的标准形式一个例子理解单纯形法1. 将线性规划转化为标准形式2. 找到一个初始可行解3. 旋转操作4. 重复旋转 一些badcase退化初始解不是可行解以及无解的情况找不到有限制条件的替入变量——无界解 时间复杂度参考资料 前言 大学的《运筹学》课程中&…

【分享】Word文档的5个隐藏功能

编辑Word文档的过程中&#xff0c;有时候我们需要隐藏一些格式&#xff0c;或者重要信息&#xff0c;今天小编来分享4个Word文档的隐藏功能&#xff0c;记得收藏哦&#xff01; 功能1&#xff1a;隐藏文本内容 对于不想被他人看到的文本内容&#xff0c;可以设置隐藏起来。 首…

备份SQLserver数据库到本地位置

怎么选择合适的数据库备份方案&#xff1f; 有人可能会说SSMS&#xff0c;确实&#xff0c;SSMS作为一个微软官方提供的SQLserver数据库管理工具&#xff0c;是可以帮助我们完成对数据库的备份还原任务的&#xff0c;但是它也有一些局限性&#xff0c;比如不能进行批量化的备份…

区块链技术与大数据结合的商业模式探索

hello宝子们...我们是艾斯视觉擅长ui设计和前端开发10年经验&#xff01;希望我的分享能帮助到您&#xff01;如需帮助可以评论关注私信我们一起探讨&#xff01;致敬感谢感恩&#xff01; 随着区块链技术和大数据技术的不断发展&#xff0c;两者的结合为企业带来了新的商业模式…

大话设计模式之装饰模式

装饰模式&#xff08;Decorator Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许向现有对象动态地添加新功能&#xff0c;同时又不改变其结构。装饰模式通过将对象放入包装器中来实现&#xff0c;在包装器中可以动态地添加功能。 在装饰模式中&#xff0c;通常会有…

碳素光线疗法与宠物健康

碳素光线与宠物健康 生息在地球上的所有动物、在自然太阳光奇妙的作用下、生长发育。太阳光的能量使它们不断进化、繁衍种族。现在、生物能够生存、全仰仗于太阳的光线。太阳光线中、包含有动物健康所需要的极为重要的波长。因此、和户外饲养的动物相比、在室内喂养的观赏动物、…

基于深度学习的心律异常分类算法

基于深度学习的心律异常分类系统——算法设计 第一章 研究背景算法流程本文研究内容 第二章 心电信号分类理论基础心电信号产生机理MIT-BIH 心律失常数据库 第三章 心电信号预处理心电信号噪声来源与特点基线漂移工频干扰肌电干扰 心电信号读取与加噪基于小波阈值去噪技术的应用…

JetBrains全家桶激活,分享 WebStorm 2024 激活的方案

大家好&#xff0c;欢迎来到金榜探云手&#xff01; WebStorm公司简介 JetBrains 是一家专注于开发工具的软件公司&#xff0c;总部位于捷克。他们以提供强大的集成开发环境&#xff08;IDE&#xff09;而闻名&#xff0c;如 IntelliJ IDEA、PyCharm、和 WebStorm等。这些工具…

Tire树-不学面试后悔

先来一张图&#xff0c;看多少同学在面试中遇到这个题&#xff0c;然后被迫放弃&#xff0c;那就太可惜&#xff0c;因为这个题只要你往下看就会了 Trie&#xff08;发音类似 "try"&#xff09;或者说 前缀树 是一种树形数据结构&#xff0c;用于高效地存储和检索字…

追光而遇 沐光同行——锐捷网络召开2024教育行业核心合作伙伴论坛

3月21日,主题为“追光而遇 沐光同行”的2024锐捷网络教育行业核心伙伴论坛在福州启幕。论坛汇聚了教育行业的精英与合作伙伴,议题主要聚焦于教育行业的数字化转型与创新发展,以及如何通过技术驱动,构建智慧教育生态,推动教育事业的高质量发展。作为行业领先的ICT基础设施及解决…

AXI Memory Mapped to PCI Express学习笔记(三)——IP核参数配置

在配置 AXI Memory Mapped to PCI Express core的过程中&#xff0c;需要根据设计需求调整各种参数&#xff0c;如数据位宽、时钟频率、输入输出接口等。这些参数将直接影响IP核的行为和性能&#xff0c;因此请务必仔细选择和配置。完成配置后&#xff0c;IP核生成&#xff0c;…

[激光原理与应用-77]:基于激光器加工板卡的二次开发软件的系统软硬件架构

目录 一、1个板卡、1个激光器、1个振镜的应用架构、1个工位 &#xff08;1&#xff09;PLC &#xff08;2&#xff09;MES &#xff08;3&#xff09;加工板卡 &#xff08;4&#xff09;激光加工板卡与激光器之间的转接卡 &#xff08;5&#xff09;DB25、DB15 &#x…