一、通过border-radius绘制圆环

<div class="loading-css"></div>

.loading-css {
    width: 50px;
    /*先将loading区域变成正方形*/
    height: 50px;
    display: inline-block;
    /*将loading区域变成行内元素,防止旋转的时候,100%宽度都在旋转*/
    border: 3px solid #f3f3f3;
    /*设置四周边框大小,并将颜色设置为浅白色*/
    border-top: 3px solid red;
    /*将上边框颜色设置为红色高亮,以便旋转的时候能够看到旋转的效果*/
    border-radius: 50%;
    /*将边框和内容区域都变成圆形*/
}

@keyframes loading-360 {
    0% {
        transform: rotate(0deg); /*动画起始的时候旋转了0度*/
    }
    100% {
        transform: rotate(360deg); /*动画结束的时候旋转了360度*/
    }
}

.loading-css { /*在之前的CSS中加上动画效果即可*/
    animation: loading-360 0.8s infinite linear; /*给圆环添加旋转360度的动画,并且是无限次*/
}

此时效果如下:
image.png

二、通过svg来绘制圆环

<svg viewBox="0 0 50 50" class="loading-svg">
    <circle cx="25" cy="25" r="20" fill="none" class="path"></circle>
</svg>

.loading-svg {
    width: 50px; /*设置svg显示区域大小*/
    height: 50px;
    animation: loading-rotate 1.5s infinite ease-in-out; /*给svg也加上一个旋转动画*/
}
.path {
    stroke: #409eff; /*给画笔设置一个颜色*/
    stroke-width: 2; /*设置线条的宽度*/
    stroke-dasharray: 95, 126; /*设置实现长95,虚线长126*/
    stroke-dashoffset: 0; /*设置虚线的偏移位置*/
    animation: loading-dash 1.5s ease-in-out infinite;
}
@keyframes loading-dash {
    0% {
        stroke-dasharray: 1, 126; /*实线部分1,虚线部分126*/
        stroke-dashoffset: 0; /*前面1/126显示实线,后面125显示空白*/
    }

    50% {
        stroke-dasharray: 95, 126; /*实线部分95,虚线部分126*/
        stroke-dashoffset: -31px /*顺时针偏移31/126,即前31/126显示空白,后面3/4显示线条*/
    }

    to {
        stroke-dasharray: 6, 120; /*实线部分6,虚线部分120*/
        stroke-dashoffset: -120px; /*最后顺时针偏移120/126,即前120/126显示空白,后面6点显示线条部分*/
    }
}
@keyframes loading-rotate {
    to {
        transform: rotate(1turn); // 旋转1圈
    }
}

此时效果如下:
image.png

三、通过iconfont字体图标
可以直接通过iconfont字体图标代替圆环的绘制,直接以字体的形式显示出圆环,然后给其加上旋转动画即可,如:
我们可以在iconfont网站上下载喜欢的Loading图案。字体图标下载后,将解压后的内容拷贝到项目中,并引入其中的iconfont.css到页面中,给要显示字体图标的元素加上iconfont类样式
image.png
具体代码引入方式,可参考demo_index.html文件,里面有三种引入方式,我这边目前采用的是第二种。
image.png
代码如下:

<link rel="stylesheet" href="./font/iconfont.css">

<span class="icon-Loading iconfont"></span>

.icon-Loading {
    display: inline-block;
    color: #0086B3;
    font-size: 40px;
    animation: rotating 2s infinite linear;
}

@keyframes rotating {
    0% {
        transform: rotate(0deg) /*动画起始位置为旋转0度*/
    }

    to {
        transform: rotate(1turn) /*动画结束位置为旋转1圈*/
    }
}

此时效果如下:
image.png


墨城
1.7k 声望2.1k 粉丝

« 上一篇
常用Git命令
下一篇 »
Git 常用命令