本文主要是介绍纯CSS3实现萧瑟深秋中律动的音乐之火,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
楔子
这是一篇活泼向的技术分享,目的是为了制作一个随着音乐节奏起舞的律动器,主要涉及以下知识点: div的垂直与水平居中方式、flex布局、backgroundImage的径向渐变背景、css3 Animation相关属性
实现
古话讲叫 大音希声 大象无形,虽然音乐是很难通过具象的东西去表达的,但音律可以通过具象的符号去表达,本文就是通过纯CSS的方式,去尝试模拟音符的律动。
- 音盒 承载我们音柱的容器,这里我们涉及到一个知识点就是一个元素的垂直与水平居中,下面我来简单的罗列一下,实现方式有脱离文档流和不脱离文档流两大类,
- 不脱离文档流的实现有:
- flex布局, 通过外层套容器写flex布局的方式来实现水平和垂直居中
display: flex;
justify-content: center; // 主轴居中
align-items: center; // 交叉轴居中
- grid布局 与flex布局类似,为了避免水字数的嫌疑,略
- 脱离文档流的实现
- 绝对定位+margin auto 适用于宽高已经设置的情形【注意:假如宽高未指定,margin:auto会拉开直至撑满容器】
position: absolute;top: 0;left: 0;right: 0;bottom: 0;margin: auto;
- 绝对定位 + transform 平移变换 【绝对定位的百分比是相对有定位属性的父级,而transform的百分比是相对自身】
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
- 音柱 主要涉及到一个径向渐变,径向渐变第一个参数是角度,表示渐变方向,后续是渐变的颜色
.music-box div{height: 200px;flex: none;width: 50px;background-image: linear-gradient(90deg, #80D6FF, #FF7EA5, #FFED3B,#8aD6FF);background-size: 500%;}
- 律动 律动的实现我们通过css3的animation属性来实现,主要是通过高度变化来模拟音乐律动,这里涉及三个知识点,一个是nth-child 伪类选择器 一个是1n 这种倍数选择器,还有就是动画的属性
.music-box div:nth-child(1n){animation: jump .3s linear 0s infinite alternate;}.music-box div:nth-child(2n){animation: jump .5s linear 0s infinite alternate;}.music-box div:nth-child(3n){animation: jump .8s linear 0s infinite alternate;}.music-box div:nth-child(5n){animation: jump 1s linear 0s infinite alternate;}@keyframes jump {10%{height: 20%;}20% {height: 50%;background-position: -100% 0;}40%{height: 30%;}60%{height: 25%;}80%{height: 0;}100%{height: 50%;}}
- 动画属性
animation: name duration timing-function delay iteration-count direction fill-mode;
从左到右属性依次是: 属性名称 持续时间 动画方式 延迟 次数 方向 填充模式,其中重点需要讲以下几个 - 动画方式: 内置的有一些,比如leaner ease 等, 也可以传入一个贝塞尔函数
- 方向: 就是从哪里开始
- 填充模式 就是 当动画完成恢复时是否还需要动画
tips:通过上面的代码实现的音乐之火是倒着的,还需要将容器进行旋转180度,才能看到一个正常律动的音柱
结尾
通过上面的代码,我们就实现了一个音乐之火,萧瑟深秋,让这个音乐之火随着你的律动跳跃吧~
最后
最近还整理一份JavaScript与ES的笔记,一共25个重要的知识点,对每个知识点都进行了讲解和分析。能帮你快速掌握JavaScript与ES的相关知识,提升工作效率。
有需要的小伙伴,可以点击下方卡片领取,无偿分享
这篇关于纯CSS3实现萧瑟深秋中律动的音乐之火的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!