• 技术文章 >web前端 >css教程

    如何使用纯CSS 实现类似于旗帜飘扬动画效果(附源码)

    不言不言2018-09-04 11:04:59原创2066
    本篇文章给大家带来的内容是关于如何使用纯CSS 实现类似于旗帜飘扬动画效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    效果预览

    2019723753-5b47ed6dc710a_articlex.gif

    源代码下载

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

    代码解读

    定义 dom,容器中包含 15 个元素:

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

    居中显示:

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

    定义容器尺寸:

    .flag {
        width: 10em;
        height: 15em;
        font-size: 20px;
    }

    设置线条样式:

    .flag span {
        width: 0.25em;
        height: inherit;
        background-color: deepskyblue;
    }

    让线条平铺:

    .flag {
        display: flex;
        justify-content: space-between;
    }

    增加 3d 透视效果:

    .flag {
        transform: perspective(500px) rotateY(-20deg);
    }

    定义左右移动的动画效果:

    .flag span {
        animation: wave 1.5s ease-in-out infinite alternate;
    }
    
    @keyframes wave {
        to {
            transform: translateX(2em);
        }
    }

    设置元素变量值:

    .flag span:nth-child(1) {
        --n: 1;
    }
    
    .flag span:nth-child(2) {
        --n: 2;
    }
    
    /* 共 15 个元素,每元素的 --n 变量值等于它的序号。 */
    /* 中间代码略 …… */
    
    .flag span:nth-child(14) {
        --n: 14;
    }
    
    .flag span:nth-child(15) {
        --n: 15;
    }

    让各线条分别延时启动动画,形成旗帜飘扬的效果:

    .flag span {
        animation-delay: calc(var(--n) * -0.1s);
    }

    最后,增加光影效果:

    .flag span {
        background-color: ghostwhite;
    }
    
    @keyframes wave {
        to {
            transform: translateX(2em);
            background-color: deepskyblue;
        }
    }

    大功告成!

    相关推荐:

    如何使用纯CSS实现小球变矩形背景的按钮悬停效果(附源码)

    如何使用CSS和D3实现小鱼游动的交互动画(附代码)

    以上就是如何使用纯CSS 实现类似于旗帜飘扬动画效果(附源码)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:动画 css3 css html5 前端
    上一篇:css固定div在页面顶部或底部的具体方法解说 下一篇:如何使用纯CSS实现一个转动的自行车车轮的动画效果
    Web大前端开发直播班

    相关文章推荐

    • 如何使用纯CSS实现一台咖啡机的效果• 如何使用纯CSS实现一个微笑打坐的小和尚• 如何使用纯CSS实现一只黑色的愤怒小鸟(附代码)• 如何使用纯CSS实现文字断开的动画效果(附源码)• 如何使用纯CSS实现带有金属光泽的立体按钮的动画效果(附源码)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网