zoukankan      html  css  js  c++  java
  • 如何用纯 CSS 创作一个过山车 loader

    效果预览

    按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。

    https://codepen.io/comehope/pen/KBxYZg/

    可交互视频

    此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

    请用 chrome, safari, edge 打开观看。

    https://scrimba.com/p/pEgDAM/cagbkSL

    源代码下载

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

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

    代码解读

    定义 dom,容器中包含 3 个元素,代表 3 个圆点:

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

    居中显示:

    body {
        margin: 0;
        height: 100vh;
        display: flex;
        align-items: center;
        justify-content: center;
        background: linear-gradient(to right, silver, teal);
    }
    

    定义摩天轮的直径,其他长度均以此值为基本尺度:

    .loader {
        --diameter: 10em;
    }
    

    定义容器尺寸,宽是高的2倍:

    .loader {
        -- calc(var(--diameter) * 2);
         var(--width);
        height: var(--diameter);
    }
    

    定义伪元素的共享属性:

    .loader {
        position: relative;
    }
    
    .loader::before,
    .loader::after {
        content: '';
        position: absolute;
        bottom: 0;
    }
    

    画出底部的轨道,同时定义了一个表示线粗细的变量:

    .loader {
        --stroke- calc(var(--diameter) / 40);
        color: white;
    }
    
    .loader::before {
         inherit;
        height: var(--stroke-width);
        background-color: currentColor;
    }
    

    画出中部的圆形轨道:

    .loader::after {
        box-sizing: border-box;
         var(--diameter);
        height: var(--diameter);
        border: var(--stroke-width) solid;
        border-radius: 50%;
        left: 25%;
    }
    

    画出一个圆点,同时定义了一个表示圆点直径的变量:

    .loader {
        --dot-diameter: calc(var(--diameter) / 10);
    }
    
    .loader span {
        position: absolute;
         var(--dot-diameter);
        height: var(--dot-diameter);
        background-color: currentColor;
        border-radius: 50%;
        bottom: var(--stroke-width);
        left: calc((var(--width) - var(--dot-diameter)) / 2);
    }
    

    为圆点增加沿圆形轨道旋转的动画效果:

    .loader span {
        animation:
            rotating 2s linear infinite;
        --vertical-center: calc((var(--diameter) / 2 - var(--stroke-width) - var(--dot-diameter)) * -1);
        transform-origin: 50% var(--vertical-center);
    }
    
    @keyframes rotating {
        0%, 10% {
            transform: rotate(0deg);
        }
    
        60%, 100% {
            transform: rotate(-1turn);
        }
    }
    

    为圆点增加移动的动画效果:

    .loader span {
        animation:
            run 2s linear infinite,
            rotating 2s linear infinite;
    }
    
    @keyframes run {
        0% {
            left: calc(var(--dot-diameter) * -1);
        }
    
        10%, 60% {
            left: calc((var(--width) - var(--dot-diameter)) / 2);
        }
    
        70%, 100% {
            left: calc(var(--width));
        }
    }
    

    为另外 2 个圆点设置动画延时,使 3 个圆点看起来像是紧挨着的 3 个车厢:

    .loader span:nth-child(1) {
        animation-delay: 0.075s;
    }
    
    .loader span:nth-child(2) {
        animation-delay: 0.15s;
    }
    

    最后,隐藏容器外的内容:

    .loader {
        overflow: hidden;
    }
    

    大功告成!

    原文地址:https://segmentfault.com/a/1190000015924973
  • 相关阅读:
    吴裕雄--天生自然Numpy库学习笔记:NumPy 字节交换
    吴裕雄--天生自然Numpy库学习笔记:NumPy 排序、条件刷选函数
    吴裕雄--天生自然Numpy库学习笔记:NumPy 统计函数
    吴裕雄--天生自然Numpy库学习笔记:NumPy 算术函数
    吴裕雄--天生自然Numpy库学习笔记:NumPy 数学函数
    吴裕雄--天生自然Numpy库学习笔记:NumPy 字符串函数
    吴裕雄--天生自然Numpy库学习笔记:NumPy 位运算
    吴裕雄--天生自然Numpy库学习笔记:Numpy 数组操作
    吴裕雄--天生自然Numpy库学习笔记:NumPy 迭代数组
    CodeForces
  • 原文地址:https://www.cnblogs.com/lalalagq/p/10082019.html
Copyright © 2011-2022 走看看