zoukankan      html  css  js  c++  java
  • 如何用纯 CSS 创作一个极品飞车 loader

    效果预览

    在线演示

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

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

    可交互视频

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

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

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

    源代码下载

    本地下载

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

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

    代码解读

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

    <div class="loader">
        <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: linear-gradient(midnightblue, black);
    }
    

    画出 7 个方块:

    .loader {
         calc(1em * 7 + 0.15em * 6);
        height: 1.5em;
        font-size: 20px;
        display: flex;
        justify-content: space-between;
    }
    
    .loader span {
         1em;
        background-color: deepskyblue;
        border-radius: 0.1em;
    }
    

    让方块倾斜:

    .loader span {
        transform: skewX(-25deg);
    }
    

    定义闪烁的动画效果:

    .loader span {
        animation: animate 0.8s infinite alternate;
        filter: opacity(0);
    }
    
    @keyframes animate {
        to {
            filter: opacity(1);
        }
    }
    

    定义变量,设置动画延时,使效果看起来像是有一个暗色块从左到右移动:

    .loader span {
        animation-delay: calc((var(--n) - 1) * 0.2s);
    }
    
    .loader span:nth-child(1) {
        --n: 1;
    }
    
    .loader span:nth-child(2) {
        --n: 2;
    }
    
    .loader span:nth-child(3) {
        --n: 3;
    }
    
    .loader span:nth-child(4) {
        --n: 4;
    }
    
    .loader span:nth-child(5) {
        --n: 5;
    }
    
    .loader span:nth-child(6) {
        --n: 6;
    }
    
    .loader span:nth-child(7) {
        --n: 7;
    }
    

    最后,增加色块的缩放效果:

    .loader span {
        transform: skewX(-25deg) scale(0.1);
    }
    
    @keyframes animate {
        to {
            filter: opacity(1);
            transform: skewX(-25deg) scale(1);
        }
    }
    

    大功告成!

    原文地址:https://segmentfault.com/a/1190000015700996
  • 相关阅读:
    模-数(A/D)转换器
    数-模(D/A)转换器
    VIM 常用命令
    Linux常用命令
    一个开关电源传导、辐射处理案例-----Layout环路
    解决:PADS导入.DXF结构图出现坐标超出范围问题
    Python3-threading模块-多线程
    Python3-socketserver模块-网络服务器框架
    Python3-socket模块-低级网络接口
    Python3-面向对象
  • 原文地址:https://www.cnblogs.com/lalalagq/p/10077683.html
Copyright © 2011-2022 走看看