CSS3实现动态进度条

CSS3的线性渐变使制造动态进度条成为可能。现在就来一步一步讲解如何创建动态进度条吧。以Chrome浏览器webkit内核为例。

目标:
这里写图片描述

单个矩形条背景

目标进度条,背景是淡蓝色,上面平铺了一层倾斜的深蓝色条状矩形。我们可以这样写:

.box{
           width:200px;
           height:30px;
           background: -webkit-linear-gradient(0deg, #83a7cf 0, #83a7cf 10px,#93b3d6 10px, #93b3d6 20px);
        }
<div class="box"></div>

这里写图片描述

这里用到了线性渐变 -webkit-linear-gradient(逆时针倾斜的角度, 颜色值 开始的位置, 颜色值 开始的位置,颜色值 开始的位置, 颜色值 开始的位置);
第一个参数除了使用倾斜角度,还可以使用“top right bottom left”,颜色值开始的位置可以用px也可以用百分数。感兴趣的可以仔细研究一下这个属性,可以制作出各种各样的神奇效果哦。
首先,我们在0-10px之间绘制了一个深蓝色的矩形条,接着又在10-20px之间绘制了一个淡蓝色的矩形条,浏览器默认将淡蓝色向后填充,因此绘制出上图。

repeat 矩形条

现在,我们希望将深蓝和浅蓝相间的矩形条重复绘制。只要修改下面一个属性即可。

background: -webkit-repeating-linear-gradient(0deg, #83a7cf 0, #83a7cf 10px,#93b3d6 10px, #93b3d6 20px);

这里写图片描述

倾斜一定角度

大概的形状已经有啦,现在修改倾斜角度即可。现逆时针旋转30度吧~

background: -webkit-repeating-linear-gradient(30deg, #83a7cf 0, #83a7cf 10px,#93b3d6 10px, #93b3d6 20px);

这里写图片描述

动起来

现在是不是已经很接近了?现在主要想让它动起来。这个时候我们可以用到CSS3的keyframe属性,来改变box的背景的位置,让它自动运动。因此,box的长度需要增加,同时需要一个盒子来使box超出的部分隐藏掉。

    .wrap{
        width: 200px;
        height: 30px;
        border-radius: 15px;
        margin: 40px;
        overflow: hidden;
    }
    .box{
        width:400px;
        height:30px;
        background: -webkit-repeating-linear-gradient(30deg, #83a7cf 0, #83a7cf 10px,#93b3d6 10px, #93b3d6 20px);
        -webkit-animation: move 5s linear infinite;
    }
    @-webkit-keyframes move{
        0%{
            background-position: 0 0;
        }
        100%{
            background-position: -200px 0;
        }
    }
    <div class="wrap">
        <div class="box">
        </div>
    </div>

这里写图片描述

添加文字

最后在box里面添加文字和相应的样式就可以了

.text{
        width: 200px;
        height: 30px;
        text-align: center;
        line-height: 30px;
        color: #ece8e8;
        font-family: arial;
    }
<div class="wrap">
    <div class="box">
        <div class="text">LOADING...</div>
    </div>
</div>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值