这是一篇活泼向的技术分享,目的是为了制作一个随着音乐节奏起舞的律动器,主要涉及以下知识点: div的垂直与水平居中方式、flex布局、backgroundImage的径向渐变背景、css3 Animation相关属性
古话讲叫 大音希声 大象无形,虽然音乐是很难通过具象的东西去表达的,但音律可以通过具象的符号去表达,本文就是通过纯CSS的方式,去尝试模拟音符的律动。
display: flex;
justify-content: center; // 主轴居中
align-items: center; // 交叉轴居中
position: absolute;top: 0;left: 0;right: 0;bottom: 0;margin: auto;
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%;}
.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;
从左到右属性依次是: 属性名称 持续时间 动画方式 延迟 次数 方向 填充模式,其中重点需要讲以下几个tips:通过上面的代码实现的音乐之火是倒着的,还需要将容器进行旋转180度,才能看到一个正常律动的音柱
通过上面的代码,我们就实现了一个音乐之火,萧瑟深秋,让这个音乐之火随着你的律动跳跃吧~
最近还整理一份JavaScript与ES的笔记,一共25个重要的知识点,对每个知识点都进行了讲解和分析。能帮你快速掌握JavaScript与ES的相关知识,提升工作效率。
有需要的小伙伴,可以点击下方卡片领取,无偿分享