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

    如何使用纯CSS实现蚊香燃烧的效果(附源码)

    不言不言2018-09-18 17:45:39原创1416
    本篇文章给大家带来的内容是关于如何使用纯CSS实现传统蚊香燃烧的效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    效果预览

    3235001503-5b1ddfb66be51_articlex.png

    源代码下载

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

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

    代码解读

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

    <div class="coil">
        <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: radial-gradient(circle at center, midnightblue, black);
    }

    画出纹香盘要用的框线:

    .coil {
        position: relative;
        display: flex;
        justify-content: center;
    }
    
    .coil span {
        position: absolute;
        width: calc((var(--n) * 2 - 1) * 1em);
        height: calc((var(--n) - 0.5) * 1em);
        border: 1em solid darkgreen;
    }
    
    .coil span:nth-child(1) {
        --n: 1;
    }
    
    .coil span:nth-child(2) {
        --n: 2;
    }
    
    .coil span:nth-child(3) {
        --n: 3;
    }
    
    .coil span:nth-child(4) {
        --n: 4;
    }
    
    .coil span:nth-child(5) {
        --n: 5;
    }
    
    .coil span:nth-child(6) {
        --n: 6;
    }
    
    .coil span:nth-child(7) {
        --n: 7;
    }
    
    .coil span:nth-child(8) {
        --n: 8;
    }

    把一半框线放置到上方:

    .coil span:nth-child(odd) {
        align-self: flex-end;
    }

    删除掉上方框线的下边框,和下方框线的上边框:

    .coil span:nth-child(odd) {
        border-bottom: none;
    }
    
    .coil span:nth-child(even) {
        border-top: none;
    }

    对齐上下边框:

    .coil span:nth-child(even) {
        transform: translateX(-1em);
    }

    把边框改为曲线:

    .coil span:nth-child(odd) {
        border-radius: 50% 50% 0 0 / 100% 100% 0 0;
    }
    
    .coil span:nth-child(even) {
        border-radius: 0 0 50% 50% / 0 0 100% 100%;
    }

    用伪元素画出蚊香最中间的部分:

    .coil::before {
        content: '';
        position: absolute;
        width: 1em;
        height: 1em;
        background-color: darkgreen;
        border-radius: 50%;
        left: -1.5em;
        top: -0.5em;
    }

    用伪元素画出蚊香的燃点:

    .coil::after {
        content: '';
        position: absolute;
        width: 1em;
        height: 1em;
        border-radius: 50%;
        top: -0.5em;
        background-color: darkred;
        left: -9.5em;
        z-index: -1;
        transform: scale(0.9);
        box-shadow: 0 0 1em white;
    }

    最后,为燃点增加闪动的效果:

    .coil::after {
        animation: blink 1s linear infinite alternate;
    }
    
    @keyframes blink {
        to {
            box-shadow: 0 0 0 white;
        }
    }

    大功告成!

    以上就是如何使用纯CSS实现蚊香燃烧的效果(附源码)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:flex css css3 html5 前端
    上一篇:如何使用纯CSS实现菱形loader效果(附源码) 下一篇:深入理解CSS中线性渐变linear-gradient属性
    Web大前端开发直播班

    相关文章推荐

    • 如何使用纯CSS实现一台咖啡机的效果• 如何使用纯CSS实现一头绿猪的效果• 如何使用纯CSS实现一只会动的手(附源码)• 如何使用纯CSS实现悬停时右移的按钮效果(附源码)• 如何使用纯CSS实现抽象的水波荡漾的动画(附源码)• 如何使用纯CSS实现在容器中反弹的小球(附源码)• 如何使用纯CSS实现菱形loader效果(附源码)

    全部评论我要评论

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

    PHP中文网