博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
前端每日实战:101# 视频演示如何用 CSS 和 D3 创作一组摆线
阅读量:5813 次
发布时间:2019-06-18

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

图片描述

效果预览

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

可交互视频

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

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

源代码下载

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

代码解读

定义 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;

大功告成!

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

你可能感兴趣的文章
lseek, fallocate来快速创建一个空洞文件,lseek不占用空间,fallocate占用空间(快速预分配)。...
查看>>
Linux下获取程序信息的几种方法
查看>>
关于数组与指针
查看>>
使用cmd命令里的 tasklist 和 netstat 获取当前各进程的网络连接
查看>>
Flutter Widget大全
查看>>
再谈JavaScript作用域——你确定你真的知道?
查看>>
前端怎么做用户行为统计分析
查看>>
jenkins经验
查看>>
guava cache
查看>>
iOS架构设计解耦的尝试之模块间通信
查看>>
SASS入门与实践
查看>>
分享一个功能很全的视频播放器
查看>>
【译】TypeScript 的类型(一)
查看>>
JS手写状态管理的实现
查看>>
把“事儿”办成的4个要点 | 享受工作系列
查看>>
Android 文件保存
查看>>
汇编语言学习与记录(4)
查看>>
Oracle database DataGuard 日常维护(二)主备切换
查看>>
java 企业 网站源码 模版 屏幕自适应 有前后台 springmvc SSM 生成静态化
查看>>
一则认真的区块链行业招聘贴
查看>>