如何使用CSS实现过山车loader的动画效果

本篇文章给大家带来的内容是关于如何使用css实现过山车loader的动画效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

4086344186-5b6a0ca3c84a6_articlex.gif

代码解读

定义 dom,容器中包含 3 个元素,代表 3 个圆点:

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

居中显示:

body {    margin: 0;    height: 100vh;    display: flex;    align-items: center;    justify-content: center;    background: linear-gradient(to right, silver, teal);}

定义摩天轮的直径,其他长度均以此值为基本尺度:

.loader {    --diameter: 10em;}

定义容器尺寸,宽是高的2倍:

.loader {    --width: calc(var(--diameter) * 2);    width: var(--width);    height: var(--diameter);}

定义伪元素的共享属性:

.loader {    position: relative;}.loader::before,.loader::after {    content: '';    position: absolute;    bottom: 0;}

画出底部的轨道,同时定义了一个表示线粗细的变量:

.loader {    --stroke-width: calc(var(--diameter) / 40);    color: white;}.loader::before {    width: inherit;    height: var(--stroke-width);    background-color: currentColor;}

画出中部的圆形轨道:

.loader::after {    box-sizing: border-box;    width: var(--diameter);    height: var(--diameter);    border: var(--stroke-width) solid;    border-radius: 50%;    left: 25%;}

画出一个圆点,同时定义了一个表示圆点直径的变量:

.loader {    --dot-diameter: calc(var(--diameter) / 10);}.loader span {    position: absolute;    width: var(--dot-diameter);    height: var(--dot-diameter);    background-color: currentColor;    border-radius: 50%;    bottom: var(--stroke-width);    left: calc((var(--width) - var(--dot-diameter)) / 2);}

为圆点增加沿圆形轨道旋转的动画效果:

.loader span {    animation:        rotating 2s linear infinite;    --vertical-center: calc((var(--diameter) / 2 - var(--stroke-width) - var(--dot-diameter)) * -1);    transform-origin: 50% var(--vertical-center);}@keyframes rotating {    0%, 10% {        transform: rotate(0deg);    }    60%, 100% {        transform: rotate(-1turn);    }}

为圆点增加移动的动画效果:

.loader span {    animation:        run 2s linear infinite,        rotating 2s linear infinite;}@keyframes run {    0% {        left: calc(var(--dot-diameter) * -1);    }    10%, 60% {        left: calc((var(--width) - var(--dot-diameter)) / 2);    }    70%, 100% {        left: calc(var(--width));    }}

为另外 2 个圆点设置动画延时,使 3 个圆点看起来像是紧挨着的 3 个车厢:

.loader span:nth-child(1) {    animation-delay: 0.075s;}.loader span:nth-child(2) {    animation-delay: 0.15s;}

最后,隐藏容器外的内容:

.loader {    overflow: hidden;}

相关文章推荐:

css实现导航切换的代码实例

如何使用纯CSS实现一头绿猪的效果

css3实现会动的菜单按钮(menu)效果

以上就是如何使用CSS实现过山车loader的动画效果的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 01:56:48
下一篇 2025年12月24日 01:56:57

相关推荐

  • CSS布局有哪些?css常见的布局方式(附代码)

    css布局有哪些?css布局可以让页面看起来比较美观整洁,接下来的这篇文章给大家总结了css中常见的几种布局方式,让我们具体的看一看。 水平居中布局 1、margin + 定宽 Demo .child { width: 50px; margin: 0 auto; } 运行结果: 立即学习“前端免费学…

    2025年12月24日 好文分享
    000
  • css三栏布局的三种实现方式(圣杯布局、双飞翼布局、Flex布局)

    本篇文章给大家带来的内容是关于lnmp以源码的方式记录环境搭建的过程(详细),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果图: 圣杯布局 圣杯.container{ padding:0 200px 0 180px; height:100px;}.left{ float:lef…

    2025年12月24日
    000
  • flex布局实现网易云播放器界面的布局

    这篇文章给大家介绍的内容是关于flex布局实现网易云播放器界面的布局,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 今天我们就深入项目的细节,说说每一个切图人员绕不过去的坎儿,也是jser必须要面对的一个常规任务–《网易云音乐高复用的响应式轮播图的实现》 轮播图相对于大…

    2025年12月24日 好文分享
    000
  • 什么是css?css三种样式以及文字属性的介绍

    这篇文章给大家介绍的内容是关于什么是css?css三种样式以及文字属性的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 什么是CSS? Cascading Style Sheets,简称CSS,层叠样式表。  用来修饰HTML文件,对网页元素进行排版或大小控制等操作。  也就是…

    好文分享 2025年12月24日
    000
  • css box-sizing属性(盒子模型)的用法介绍

    本篇文章给大家带来的内容是关于CSS中text-transform属性实现字符串转换的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 1.关于box-sizing: 属性用于更改用于计算元素宽度和高度的默认的 css 盒子模型。 值有:content-box(默认值),bord…

    2025年12月24日
    000
  • 如何使用纯CSS实现一头绿猪的效果

    本篇文章给大家带来的内容是关于如何使用纯css实现一头绿猪的效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-daily-ch…

    2025年12月24日
    000
  • CSS中流体布局、元素以及尺寸的介绍

    这篇文章给大家介绍的内容是关于css中流体布局、元素以及尺寸的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、 流体布局引出的几种网页布局方式 布局方式 描述 特点 场景 静态布局Static Layout,传统Web设计,网页上的所有元素的尺寸一律使用px作为单位。不管浏…

    2025年12月24日
    000
  • CSS中盒模型中四个属性的介绍(附代码)

    本篇文章给大家带来的内容是关于css中盒模型中四个属性的介绍(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、替换元素与非替换元素 根据“外在盒子”是内联还是块级我们可以把元素分为内联元素和块级元素,而根据是否具有可替换内容,我们也可以把元素分为替换元素和非替换元素 1…

    2025年12月24日
    000
  • css属性:css伪类和css伪元素的区别(附代码)

    css伪元素和伪类对于刚学习css的同学来说可能会容易混淆,官方文档中解释:css 伪类用于向某些选择器添加特殊的效果,css 伪元素是用于将特殊的效果添加到某些选择器。那么,css伪元素和伪类的区别究竟在哪?本文将给大家细细的说道说道。 首先可以明确两点,第一:两者都与选择器相关,第二:就是添加一…

    好文分享 2025年12月24日
    000
  • css浮动是什么意思?css浮动的原理以及css清除浮动的方法(附代码)

    css浮动是什么意思?所谓css浮动就是浮动元素会脱离文档的普通流,根据float的值向左或向右移动,直到它的外边界碰到父元素的内边界或另一个浮动元素的外边界为止。由于浮动框不在文档的普通流中,所以文档的普通流中的块级元素表现得就像浮动元素不存在一样。接下来,本文讲给大家说一说css浮动的原理以及c…

    2025年12月24日 好文分享
    000
  • 如何使用CSS实现圆点移动的动图效果

    这篇文章给大家分享的内容是关于如何使用css实现圆点移动的动图效果,有一定的参考价值,有需要的朋友可以从参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 dom,容器中包含…

    2025年12月24日
    000
  • CSS 网格布局(Grid)的两种方式介绍(附代码)

    css 网格布局(grid)能够将网页分成具有简单属性的行和列,可以直接使用 css 来定位和调整网格内的每个元素,也不需要为了实现某种布局进行多层嵌套,总而言之,css网格布局非常好用,下面我们就来看一看这篇文章给大家讲述的css网格布局的内容。 1、CSS 网格布局(Grid) CSS Grid…

    好文分享 2025年12月24日
    000
  • css布局中格式化上下文(FC)类型有哪些?格式化上下文(FC)的类型介绍

    什么是格式化上下文(fc)?格式化上下文(formatting context),指页面中一个渲染区域,拥有一套渲染规则,它决定了其子元素如何定位,以及与其他元素的相互关系和作用,那么css布局中格式化上下文有哪些呢?下面这篇文章给大家介绍了几种格式化上下文的类型。 块级格式上下文(BFC): 什么…

    好文分享 2025年12月24日
    000
  • 浅析CSS边框属性:宽度&样式&边框等

    这篇文章给大家介绍的内容是关于浅析css边框属性:宽度&样式&边框等,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 定义和用法 围绕元素内容和内边距的一条或多条线。 基本属性:宽度、样式、颜色 宽度 border-width 立即学习“前端免费学习笔记(深入)”; …

    好文分享 2025年12月24日
    000
  • CSS背景属性有哪些?css背景属性的总结(附代码)

    css背景属性是用于定义html元素背景的,那么,css背景属性有哪些呢?像是css背景颜色属性,css图片背景属性都属于css背景属性,本文将给大家总结一下css背景属性中相关的属性。 首先,我们来看一下css相关的属性: background-color: css设置背景颜色 backgroun…

    好文分享 2025年12月24日
    000
  • css3中新增属性:css3多列布局属性的总结(附实例)

    css3中增加了多列布局的属性,什么是多列布局呢?所谓多列布局,就是创建多个列来对文本进行布局,像是报纸的排版差不多,那么,在本文中我们就来看一看多列布局中的一些相关属性及代码实例。 css3多列布局容器的属性: column-width: auto | :给列定义一个最小宽度(min-width)…

    2025年12月24日
    000
  • 多列布局的概念是什么?CSS多列布局的应用(实例代码)

    这篇文章给大家介绍的内容是关于多列布局的概念是什么?css多列布局的应用(实例代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 多列布局 CSS3 可以将文本内容设计成像报纸一样的多列布局,如下实例: 代码如下(具体的解释也在代码中)浏览器支持表格中的数字表示支持该方法的第一个…

    2025年12月24日 好文分享
    000
  • 如何实现单行文字向上滚动的效果(附代码)

    这篇文章给大家介绍的内容是关于如何实现单行文字向上滚动的效果(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 最近在做一个活动页,需要一个单行文字向上滚动的效果来展示获奖公告。 效果如下: 废话不多说,下面直接贴上代码。 html代码如下: @@##@@ {{item.ph…

    2025年12月24日
    000
  • 汇总css布局的发展史,就属第四代css布局技术最牛掰

    我也是在前端行业混过几年的老人了,css网页布局也变的丰富起来,致使我也在不断的学习进步,不然真的跟不上时代的潮流啊,当第四代css布局技术网格布局呈现在我眼前的时候,好似似曾相识呢,但是又很陌生,不得不重新学习,之前的每一个开发者的电脑上还都装着一个frontpage,就连dreamwaver8都…

    2025年12月24日 好文分享
    000
  • CSS中transform-origin属性是做什么的?transform-origin属性的作用

    这篇文章给大家介绍的内容是关于css中transform-origin属性是做什么的?transform-origin属性的作用,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助 最近做的一个烟花动画,就是烟花散开的动画,在动画的实现过程中,主要在烟花旋转过程中卡住了,后来发现主要对tr…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信