如何使用纯CSS实现方块跳跃的动画(附源码)

本篇文章给大家带来的内容是关于如何使用纯css实现方块跳跃的动画(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

68468092-5b90552318ad1_articlex.gif

源代码下载

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,容器中包含 2 个子元素,分别代表 1 个女生和一群男生(4个),每个 span 元素代表 1 个人(1 个方块):

居中显示:

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

body {    margin: 0;    height: 100vh;    display: flex;    align-items: center;    justify-content: center;}

定义容器尺寸和它的子元素布局:

.container {    width: 8em;    height: 1em;    font-size: 35px;    display: flex;    justify-content: space-between;}

画出 5 个方块,用边框作为辅助线帮助定位:

.container span {    width: 1em;    height: 1em;    border: 1px dashed black; /* 辅助线 */}.boys {    width: 6em;    display: flex;    justify-content: space-between;}

用伪元素设置元素的样式,使它们变得柔和一些,为男生和男生填上不同的颜色,同时删掉上一步的辅助线:

.container span::before {        content: '';    position: absolute;    width: inherit;    height: inherit;    border-radius: 15%;    box-shadow: 0 0 0.2em rgba(0, 0, 0, 0.3);}.girl::before {    background-color: hotpink;}.boys span::before {    background-color: dodgerblue;}

使 4 个男生色块的颜色逐渐变淡,增加一点层次感:

.boys span:nth-child(1)::before {    filter: brightness(1);}.boys span:nth-child(2)::before {    filter: brightness(1.15);}.boys span:nth-child(3)::before {    filter: brightness(1.3);}.boys span:nth-child(4)::before {    filter: brightness(1.45);}

接下来制作动画效果。

先增加女生移动的效果,同时颜色也做渐淡处理,后面其他动画的时间要保持一致,所以把动画时长设置为变量:

.container span {    width: 1em;    height: 1em;    --duration: 3s;}.girl {    animation: slide var(--duration) ease-in-out infinite;}@keyframes slide {    from {        transform: translateX(0);        filter: brightness(1);    }    to {        transform: translatex(calc(8em - (1em * 1.25)));        filter: brightness(1.45);    }}

然后增加第 1 个男生跳开的动画效果,注意从 15% 到 35% 旋转的原点是在元素的正上方:

.boys span {    animation: var(--duration) ease-in-out infinite;}.boys span:nth-child(1) {    animation-name: jump-off-1;}@keyframes jump-off-1 {    0%, 15% {        transform: rotate(0deg);    }    35%, 100% {        transform-origin: -50% center;        transform: rotate(-180deg);    }}

参考第 1 个男生的动画效果,再增加另外 3 个男生跳开的动画效果,区别只是调整了关键帧的时间,依次后延 15% 的时间:

.boys span:nth-child(2) {    animation-name: jump-off-2;}.boys span:nth-child(3) {    animation-name: jump-off-3;}.boys span:nth-child(4) {    animation-name: jump-off-4;}@keyframes jump-off-2 {    0%, 30% {        transform: rotate(0deg);    }    50%, 100% {        transform-origin: -50% center;        transform: rotate(-180deg);    }}@keyframes jump-off-3 {    0%, 45% {        transform: rotate(0deg);    }    65%, 100% {        transform-origin: -50% center;        transform: rotate(-180deg);    }}@keyframes jump-off-4 {    0%, 60% {        transform: rotate(0deg);    }    80%, 100% {        transform-origin: -50% center;        transform: rotate(-180deg);    }}

为第 1 个男生增加拟人的动画效果,这个效果写在 ::before 伪元素中,动画的过程是从正常到压扁、然后抻长、再压扁、最后恢复正常,注意从 25% 到 40% 的压扁变形,因为此时主元素已经翻个儿,所以 transform-origin 的原点和 从 5% 到 15% 的压扁变形的原点不一样:

.boys span::before {    animation: var(--duration) ease-in-out infinite;}.boys span:nth-child(1)::before {    filter: brightness(1);    animation-name: jump-down-1;}@keyframes jump-down-1 {    5% {        transform: scale(1, 1);    }    15% {        transform-origin: center bottom;        transform: scale(1.3, 0.7);    }    20%, 25% {        transform-origin: center bottom;        transform: scale(0.8, 1.4);    }    40% {        transform-origin: center top;        transform: scale(1.3, 0.7);    }    55%, 100% {        transform: scale(1, 1);    }}

参考第 1 个男生 ::before 伪元素的动画效果,再增加另外 3 个男生拟人的动画效果,区别只是调整了关键帧的时间,依次后延 15% 的时间:

.boys span:nth-child(2)::before {    animation-name: jump-down-2;}.boys span:nth-child(3)::before {    animation-name: jump-down-3;}.boys span:nth-child(4)::before {    animation-name: jump-down-4;}@keyframes jump-down-2 {    20% {        transform: scale(1, 1);    }    30% {        transform-origin: center bottom;        transform: scale(1.3, 0.7);    }    35%, 40% {        transform-origin: center bottom;        transform: scale(0.8, 1.4);    }    55% {        transform-origin: center top;        transform: scale(1.3, 0.7);    }    70%, 100% {        transform: scale(1, 1);    }}@keyframes jump-down-3 {    35% {        transform: scale(1, 1);    }    45% {        transform-origin: center bottom;        transform: scale(1.3, 0.7);    }    50%, 55% {        transform-origin: center bottom;        transform: scale(0.8, 1.4);    }    70% {        transform-origin: center top;        transform: scale(1.3, 0.7);    }    85%, 100% {        transform: scale(1, 1);    }}@keyframes jump-down-4 {    50% {        transform: scale(1, 1);    }    60% {        transform-origin: center bottom;        transform: scale(1.3, 0.7);    }    65%, 70% {        transform-origin: center bottom;        transform: scale(0.8, 1.4);    }    85% {        transform-origin: center top;        transform: scale(1.3, 0.7);    }    100%, 100% {        transform: scale(1, 1);    }}

至此,女生从左侧移动到右侧的动画效果已经完成。
把所有动画属性都加上 alternate 参数,使所有动画都往复执行,就实现了从右侧再回到左侧的效果:

.girl {    animation: slide var(--duration) ease-in-out infinite alternate;}.boys span {    animation: var(--duration) ease-in-out infinite alternate;}.boys span::before {    animation: var(--duration) ease-in-out infinite alternate;}

大功告成!

相关推荐:

如何使用纯CSS实现一个圆环旋转错觉的动画效果(附源码)

如何使用纯CSS实现蝴蝶标本的展示框效果

以上就是如何使用纯CSS实现方块跳跃的动画(附源码)的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 02:17:13
下一篇 2025年12月24日 02:17:33

相关推荐

  • ​css怎么设置无序列表?css的列表样式总结

    css怎么样设置无序列表的样式你知道吗?这里有无序列表的详细应用,去掉这些图标之类的,还介绍了去掉小圆点给添加的图片的介绍,大家可以自己试试看。现在就让我们一起来看看这篇文章吧 首先我们先来看看无序列表: 我们都知道无序列表通常都是使用小圆点代替的,但是有些时候用小圆点不好看,为了增加美观性,在cs…

    好文分享 2025年12月24日
    000
  • 如何使用纯CSS 实现类似于旗帜飘扬动画效果(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css 实现类似于旗帜飘扬动画效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 d…

    2025年12月24日
    000
  • 如何使用纯CSS实现一个转动的自行车车轮的动画效果

    本篇文章给大家带来的内容是关于如何使用纯css实现一个转动的自行车车轮的动画效果 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 do…

    2025年12月24日
    000
  • 如何使用纯CSS实现小球跳跃台阶的动画效果(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现小球跳跃台阶的动画效果(附源码) ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 d…

    2025年12月24日
    000
  • 如何使用纯CSS实现单元素麦当劳的Logo(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现单元素麦当劳的logo(附源码) ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 d…

    2025年12月24日
    000
  • 如何使用纯CSS实现Windows启动界面的动画效果

    本篇文章给大家带来的内容是关于如何使用纯css实现windows启动界面的动画效果 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 d…

    2025年12月24日
    000
  • 如何使用纯CSS实现蝴蝶标本的展示框效果

    本篇文章给大家带来的内容是关于如何使用纯css实现蝴蝶标本的展示框效果 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-end-dail…

    2025年12月24日
    000
  • 如何使用纯CSS实现一个足球场的俯视图(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现一个足球场的俯视图(附源码) ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 dom…

    2025年12月24日
    000
  • 如何使用纯CSS实现太阳和地球和月亮的运转模型动画

    这篇文章给大家带来的内容是关于如何使用纯css实现太阳和地球和月亮的运转模型动画 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义dom…

    2025年12月24日
    000
  • html中的字体颜色怎么设置?css设置字体颜色方法介绍

    在html中我们经常要用到css样式来美化html标签的一些不足之处,今天我们就来说说如何用css的基本样式来改变文本的颜色,文章通俗易懂,希望大家看完后能练习练习加深印象。 一、首先我们先给大家看个html字体的基础代码: PHP中文网这里是PHP中文网html这里是PHP中文网css这里是PHP…

    2025年12月24日
    000
  • css块级元素的定义是什么?css块级元素有哪些?

    css块级元素是什么?对于一些刚学习css的朋友们来说,这个问题可能不太了解,那么,接下来这篇文章就来给大家介绍一下关于css块级元素的定义,以及css块级元素有哪些? css块级元素的定义 根据W3C上的解释,就是说block(块级)元素是独占一行显示的。它的兄弟元素必定不会与其在同一行中(除非脱…

    好文分享 2025年12月24日
    000
  • css行内元素有哪些?css块级元素和行内元素的区别

    很多css初学者在学习到css行内元素和css块级元素的时候,可能会容易搞混,那么,本篇文章就来给大家讲解一下css行内元素和块级元素有哪些?以及css块级元素和css行内元素的区别。 在上一篇文章css块级元素的定义是什么?css块级元素有哪些?中我们单独介绍css的块级(block)元素,所以在…

    2025年12月24日
    000
  • 如何使用纯CSS实现一个圆环旋转错觉的动画效果(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现一个圆环旋转错觉的动画效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 dom,容…

    2025年12月24日
    000
  • CSS常见兼容性问题及解决方法的总结

    本篇文章给大家带来的内容是关于CSS常见兼容性问题及解决方法的总结 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 浏览器的兼容性问题,通常是因为不同的浏览器对同一段代码有不同的解析,造成页面显示不统一的情况。 这里谈到的浏览器,主要指IE6/IE7/IE… FireF…

    2025年12月24日
    000
  • 如何使用纯CSS实现一只纸鹤(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现一只纸鹤(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 dom,容器中包含…

    2025年12月24日
    000
  • 什么是BFC?css中的BFC有什么用?

    本篇文章给大家带来的内容是关于什么是bfc?css中的bfc有什么用?,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 什么是BFC(Block Formatting Context) Formatting context(格式化上下文) 是 W3C CSS2.1 规范中的一个概念。…

    2025年12月24日
    000
  • 如何使用纯CSS实现一个人独自行走的动画效果(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现一个人独自行走的动画效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 d…

    2025年12月24日
    000
  • css盒子模型的理解:5分钟搞懂css盒子模型是什么?

    css盒子模型是什么?毕竟在学习css时经常可以看到css盒子模型,所以,接下来的这篇文章创想鸟就跟大家来谈一谈css盒子模型的概念以及对css盒子模型的理解。 首先,我们来看一看css盒子模型是什么? 从百度百科上我们可以知道,网页设计中常听的属性名:内容(content)、内边距(padding…

    2025年12月24日 好文分享
    000
  • css继承是什么意思?css哪些属性可以继承?

    在css的学习过程中,我们会遇到一些属性可以继承,那么,css中的继承是什么意思?有哪些属性可以继承呢?本篇文章就给大家来介绍一下css中继承性的内容。 我们定义css继承前,先来看一看HTML DOM(文档树),HTML DOM(文档树)是由html元素组成,文档树和家族树类似,也有祖先、后代、父…

    好文分享 2025年12月24日
    000
  • 如何使用纯CSS实现抛盒子的loader (附源码)

    本篇文章给大家带来的内容是关于 如何使用纯css实现抛盒子的loader (附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 d…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信