博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何用 CSS 和 D3 创作一组摆线
阅读量:6430 次
发布时间:2019-06-23

本文共 2350 字,大约阅读时间需要 7 分钟。

在这里插入图片描述

效果预览

按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。

可交互视频

此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

请用 chrome, safari, edge 打开观看。

源代码下载

每日前端实战系列的全部源代码请从 github 下载:

代码解读

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

<div class="pendulums">    <span></span>    <span></span>    <span></span></div>

居中显示:

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 库:

<script src="https://d3js.org/d3.v5.min.js"></script>

用 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;```

大功告成!

原文地址:https://segmentfault.com/a/1190000015953665

转载地址:http://tciga.baihongyu.com/

你可能感兴趣的文章
【20181023T1】战争【反向并查集】
查看>>
win7网络共享原来如此简单,WiFi共享精灵开启半天都弱爆了!
查看>>
iOS9 未受信任的企业级开发者
查看>>
paper 40 :鲁棒性robust
查看>>
优化MySchool数据库(事务、视图、索引)
查看>>
使用笔记:TF辅助工具--tensorflow slim(TF-Slim)
查看>>
大话设计模式读书笔记3——单例模式
查看>>
实验三
查看>>
Vue 项目构建
查看>>
[Ruby on Rails系列]2、开发环境准备:Ruby on Rails开发环境配置
查看>>
android studio adb
查看>>
框架源码系列二:手写Spring-IOC和Spring-DI(IOC分析、IOC设计实现、DI分析、DI实现)...
查看>>
asp.net编译 懒人脚本
查看>>
二分答案经典入门题:)
查看>>
为什么你需要将代码迁移到ASP.NET Core 2.0?
查看>>
Servlet的多线程和线程安全
查看>>
存储树形的数据表转为Json
查看>>
CAN 总线通信控制芯片SJA1000 的读写
查看>>
oauth授权协议的原理
查看>>
OutputCache说明
查看>>