如何使用CSS 和D3实现摆线摇摆的效果动画

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

效果预览

1165599247-5b6cd55b9bc03_articlex.gif

代码解读

定义 dom,容器中包含 3 个元素,代表 3 条摆线:

居中显示:

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

定义容器的尺寸,并画出固定摆线示意墙:

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

.pendulums {    width: 40em;    height: 30em;    font-size: 10px;    border-top: 0.3em solid cadetblue;}

画出一条摆线:

.pendulums {    position: relative;}.pendulums span {    position: absolute;    width: 0.2em;    height: 15em;    background-color: cadetblue;    left: 50%;}

用伪元素画出摆线底部悬挂的小球:

.pendulums span::before {    content: '';    position: absolute;    width: 1.5em;    height: 1.5em;    background: steelblue;    border-radius: 50%;    top: 100%;    left: -0.75em;}

用径向渐变为小球增加光影:

.pendulums span::before {    background: radial-gradient(        circle at 70% 35%,        white,        darkturquoise 30%,        steelblue 50%    );}

用伪元素画出小球的阴影:

.pendulums span::after {    content: '';    position: absolute;    width: 2em;    height: 0.3em;    background-color: rgba(0, 0, 0, 0.2);    top: 120%;    left: -1em;    filter: blur(0.4em);}

以摆线的顶点为原点,将摆线向左旋转:

.pendulums span {    transform-origin: 50% top;    transform: rotate(25deg);}

让摆线摆动起来:

.pendulums span {    animation: swing ease-in-out infinite;    animation-duration: 1.5s;}@keyframes swing {    50% {        transform: rotate(-25deg);    }}

为每条摆线定义下标变量:

.pendulums span:nth-child(1) {    --n: 1;}.pendulums span:nth-child(2) {    --n: 2;}.pendulums span:nth-child(3) {    --n: 3;}

用变量设置摆线的长度,和动画的时长,都是逐渐增大的等差数列:

.pendulums span {    height: calc((var(--n) - 1) * 1em + 15em);    animation-duration: calc((var(--n) - 1) * 0.02s + 1.5s);}

接下来用 d3 来批量处理 dom 元素和 css 变量:
引入 d3 库:


用 d3 创建摆线的 dom 元素:

const COUNT = 3;d3.select('.pendulums')    .selectAll('span')    .data(d3.range(COUNT))    .enter()    .append('span')

用 d3 定义摆线的下标变量:

d3.select('.pendulums')    .selectAll('span')    .data(d3.range(COUNT))    .enter()    .append('span')    .style('--n', (d) => d + 1);

删除掉 html 文件中相关的 dom 定义和 css 文件中的变量定义。

最后,把摆线的数量调整为 15 个。

const COUNT = 15;

相关推荐:

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

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

以上就是如何使用CSS 和D3实现摆线摇摆的效果动画的详细内容,更多请关注创想鸟其它相关文章!

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

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

相关推荐

  • css3中animation属性实现箭头向右滚动渐隐的代码

    这篇文章给大家介绍的内容是关于css3中animation属性实现箭头向右滚动渐隐的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 这是一个右箭头的小图标。 keyframes 创建一个css3动画用 animation 调用 并用延迟动画的办法 做出匀速滚动的效果。 直接贴上…

    好文分享 2025年12月24日
    000
  • css实现表格的行和列相互交换的代码

    这篇文章给大家介绍的内容是关于css实现表格的行和列相互交换的代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 行列互换table {border: 1px solid #ccc;font-size: 14px;}table th {background: orange;colo…

    好文分享 2025年12月24日
    000
  • css如何在菜单上实现对勾?(代码)

    本篇文章给大家带来的内容是关于css如何在菜单上实现对勾?(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 :after :before li { list-style-type: none; position: relative; margin: 2px; padding:…

    2025年12月24日
    000
  • css实现布局时可以用的几个技巧(代码)

    本篇文章给大家带来的内容是关于css实现布局时可以用的几个技巧(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 面对似曾相识的布局 侧边固定中间自适应,头部固定中间自适应,长得差不多的panel组件,model组件 我们有前端框架bootstrap,easyui都有提供这些组…

    好文分享 2025年12月24日
    000
  • css中Flex布局如何实现九宫格的样式(代码)

    本篇文章给大家带来的内容是关于css中flex布局如何实现九宫格的样式(代码) ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 .block { padding-top: 30%; margin-top: 3%; border-radius: 10%; background-col…

    2025年12月24日
    000
  • CSS布局有哪些?css常见的布局方式(附代码)

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

    2025年12月24日 好文分享
    000
  • 如何使用CSS实现过山车loader的动画效果

    本篇文章给大家带来的内容是关于如何使用css实现过山车loader的动画效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 代码解读 定义 dom,容器中包含 3 个元素,代表 3 个圆点: 立即学习“前端免费学习笔记(深入)”; 居中显示: body { margin:…

    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

发表回复

登录后才能评论
关注微信