HTML5+CSS3小实例:手风琴式加载动画

380 阅读1分钟

HTML5+CSS3做一个手风琴式的加载动画,这动画、这质感、这配色,就问你喜不喜欢?!这个案例的知识点主要是:css的自定义属性 + 动画延迟 + 颜色滤镜(hue-rotate)。

效果:

源码:

<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="content-type" content="text/html; charset=utf-8">
    <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">

    <title>纯CSS实现漂亮的加载动画</title>
    <link rel="stylesheet" href="../css/21.css">
</head>

<body>
    <div class="loading">
        <!-- 【--x是自定义属性】 -->
        <div style="--x:0"></div>
        <div style="--x:1"></div>
        <div style="--x:2"></div>
        <div style="--x:3"></div>
        <div style="--x:4"></div>
        <div style="--x:5"></div>
    </div>
</body>

</html>
*{
    /* 取消页面内外边距 */
    margin: 0;
    padding: 0;
    /* 这个是告诉浏览器:你想要设置的边框和内边距的值是包含在总宽高内的 */
    box-sizing: border-box;
}
body{
    /* 100%窗口高度 */
    height: 100vh;
    /* 弹性布局 水平、垂直居中 */
    display: flex;
    justify-content: center;
    align-items: center;
    background: #eef1f5;
}
.loading{
    display: flex;
    /* 水平显示 */
    flex-direction: row;
}
.loading div{
    position: relative;
    width: 40px;
    height: 200px;
    background: linear-gradient(to bottom,rgba(0,0,0,0.05),#eef1f5);
    margin: 20px;
    border-radius: 20px;
    border: 2px solid #eef1f5;
    /* 阴影 */
    box-shadow: 15px 15px 20px rgba(0,0,0,0.1),
                -15px -15px 20px #fff,
                inset -5px -5px 5px rgba(255,255,255,0.5),
                inset 5px 5px 5px rgba(0,0,0,0.05);
    overflow: hidden;
}
.loading div::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    box-shadow: inset -5px -5px 5px rgba(0,0,0,0.1),
                0 420px 0 400px lightskyblue;
    /* 执行动画:动画名称 时长 加速后减速 无限次播放 */
    animation: animate 2s ease-in-out infinite;
    /* 动画延迟 通过var函数获取自定义属性--x,再由calc函数计算得出每个元素的动画延迟时间 */
    animation-delay: calc(var(--x) * -0.3s);
    /* 向上移动 */
    transform: translateY(160px);
}

/* 定义动画 */
@keyframes animate{
    0%{
        transform: translateY(160px);
        /* hue-rotate是颜色滤镜,可以设置不同的度数来改变颜色 */
        filter: hue-rotate(0deg);
    }
    50%{
        transform: translateY(0px);
        filter: hue-rotate(180deg);
    }
    100%{
        transform: translateY(160px);
        filter: hue-rotate(360deg);
    }
}