CSS3实现进度条的俩种方法

这次给大家带来CSS3实现进度条的俩种方法,CSS3实现进度条的注意事项有哪些,下面就是实战案例,一起来看一下。

效果图如下:

CSS3实现进度条的俩种方法
 

CSS3实现进度条的俩种方法
 

第一种姿势如下
 

先上代码

/*对应CSS*/    #progress{           width: 300px;           height: 30px;           border:1px solid #ccc;           border-radius: 15px;           overflow: hidden;  /*注意这里*/           box-shadow: 0 0 5px 0px #ddd inset;    }              #progress span {           display: inline-block;           width: 70%;           height: 100%;                  background: linear-gradient(45deg, #2989d8 30%,#7db9e8 31%,#7db9e8 58%,#2989d8 59%);               background-size: 60px 30px;           text-align: center;           color:#fff;           animation:load 3s ease-in;     }     @keyframes load{           0%{               width: 0%;           }           100%{               width:70%;           }       }

上方的渐变色使用了css3中的 linear-gradient
 

linear-gradient语法

 = linear-gradient([ [  | to  ] ,]? [, ]+) = [left | right] || [top | bottom] =  [  |  ]?

angle:用角度值指定渐变的方向(或角度)。

to left:设置渐变为从右到左。相当于: 270deg

to right:设置渐变从左到右。相当于: 90deg

to top:设置渐变从下到上。相当于: 0deg

to bottom:设置渐变从上到下。相当于: 180deg。这是默认值,等同于留空不写。

color-stop: 用于指定渐变的起止颜色:

color:指定颜色。

length:用长度值指定起止色位置。不允许负值

percentage:用百分比指定起止色位置。

栗子:

.test1{    background: linear-gradient(#EA2000, #E5A399);}.test2 {    background: linear-gradient(45deg,#EA2000 20%,#E5632D 50%, #E5B12D 80%);}.test3 {    background: linear-gradient(to top right, #000, #416796 50%, #B5CAE4);}.test4{    background: linear-gradient(45deg, #2989d8 30%,#7db9e8 31%,#7db9e8 58%,#2989d8 59%);   }

效果图:
 

CSS3实现进度条的俩种方法
 

动画通过keyframes来实现,通过改变span的宽度来实现进度的效果,素不素hin简单?!
 

现在的进度条效果是只有70%的效果,只要改变width的值就可以啦,就像下图,一致改成某个值即可。
 

CSS3实现进度条的俩种方法
 

第二种姿势
 

首先,构造好一个正方形的p,将这个正方形对称分成左右两块,如下
 

这里构造的是一个200px 200px的一个正方形,分成两块100px200px的矩形。

.progress2{        width: 200px;        height: 200px;        margin: 100px auto;        position: relative;        border:1px solid #ddd;    }       .rect{        width: 100px;        height: 200px;        position: absolute;        top:0;        overflow: hidden; /*注意这里*/    }    .right{        right:0;    }    .left{        left:0;    }

如下效果
 

CSS3实现进度条的俩种方法

接下来,在每一块矩形中再构造一个空心圆,先构造右半边,如下

.circle{        width: 160px;        height: 160px;        border:20px solid #ccc;        border-radius: 50%;        position: absolute;        top:0;    }    .rightcircle{        border-top:20px solid rgb(41,137,216);        border-right:20px solid rgb(41,137,216);        right:0;    }

会看到下面的效果
 

CSS3实现进度条的俩种方法
 

由于在class:rect中,将overflow设置成了hidden,使得溢出的部分被遮盖了,之后的效果实现与这个属性关系也紧密相连。
 

如果没有设置该属性,效果就是这样的。
 

CSS3实现进度条的俩种方法
 

那会发现有一部分被盖住了,我们在使他旋转45度即可

.circle{        width: 160px;        height: 160px;        border:20px solid #ccc;        border-radius: 50%;        position: absolute;        top:0;        transform: rotate(45deg); /*注意这里*/    }

效果如下
 

CSS3实现进度条的俩种方法
 

我们实现动画效果的方式就是让右半边旋转180度,然后左半边旋转180度,凑成完整的效果。
 

先给这右半边设置动画效果,即一开始让其旋转45度,然后旋转180度,由于这只是右半边,所以在50%的时候就应该旋转完毕,之后一直保持不变。

.rightcircle{        border-top:20px solid rgb(41,137,216);        border-right:20px solid rgb(41,137,216);        right:0;        animation: load_right 5s linear infinite;    }    @keyframes load_right{        0%{            transform: rotate(45deg);        }        50%{            transform: rotate(225deg);        }        100%{            transform: rotate(225deg);        }    }

这是没有在class rect中设置overflow:hidden的效果
 

CSS3实现进度条的俩种方法
 

这是在class rect中设置了overflow:hidden的效果
 

CSS3实现进度条的俩种方法
 

现在,我们就可以把左半边也凑上了,同理,动画效果一开始先旋转45度,调正,然后一直保持不变,到50%之后,再开始旋转180度。这样就与右半边衔接上了。

.leftcircle{        border-bottom:20px solid rgb(41,137,216);        border-left:20px solid rgb(41,137,216);        left:0;        animation: load_left 5s linear infinite;    }    @keyframes load_left{        0%{            transform: rotate(45deg);        }        50%{            transform: rotate(45deg);        }        100%{            transform: rotate(225deg);        }    }

这是整体的效果
 

CSS3实现进度条的俩种方法
 

可以调整角度或者调整颜色即可实现反向的效果。
 

我是调整了颜色就可以得到最开始的动画效果啦,下面是完整的代码

.progress2{        width: 200px;        height: 200px;        margin: 100px auto;        position: relative;    }       .rect{        width: 100px;        height: 200px;        position: absolute;        top:0;        overflow: hidden;    }    .right{        right:0;    }    .left{        left:0;    }    .circle{        width: 160px;        height: 160px;        border:20px solid rgb(41,137,216);        border-radius: 50%;        position: absolute;        top:0;        transform: rotate(45deg);    }    .rightcircle{        border-top:20px solid #ccc;        border-right:20px solid #ccc;        right:0;        animation: load_right 5s linear infinite;    }    .leftcircle{        border-bottom:20px solid #ccc;        border-left:20px solid #ccc;        left:0;        animation: load_left 5s linear infinite;    }    @keyframes load_right{        0%{            transform: rotate(45deg);        }        50%{            transform: rotate(225deg);        }        100%{            transform: rotate(225deg);        }    }    @keyframes load_left{        0%{            transform: rotate(45deg);        }        50%{            transform: rotate(45deg);        }        100%{            transform: rotate(225deg);        }    }

CSS3实现进度条的俩种方法

相信看了本文案例你已经掌握了方法,更多精彩请关注创想鸟其它相关文章!

推荐阅读:

用CSS3实现头像旋转效动画

css的background-attachment进阶使用方法

css做出波纹动画

以上就是CSS3实现进度条的俩种方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1609558.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 00:50:37
下一篇 2025年12月24日 00:50:51

相关推荐

  • 在CSS实现Footer置底的几种方式

    这次给大家带来在CSS实现Footer置底的几种方式,在CSS实现Footer置底的注意事项有哪些,下面就是实战案例,一起来看一下。 页脚置底(Sticky footer)就是让网页的footer部分始终在浏览器窗口的底部。 当网页内容足够长以至超出浏览器可视高度时,页脚会随着内容被推到网页底部;但…

    好文分享 2025年12月24日
    000
  • CSS有多少清除浮动的方式

    这次给大家带来CSS有多少清除浮动的方式,清除浮动的注意事项有哪些,下面就是实战案例,一起来看一下。 1、设置父元素高度 如果一个元素要浮动,那么它的祖先元素一定要有高度.高度的盒子,才能关住浮动 只要浮动在一个有高度的盒子中,那么这个浮动就不会影响后面的浮动元素.所以就是清除浮动带来的影响了. 弊…

    2025年12月24日
    000
  • CSS的Selector使用详解

    这次给大家带来CSS的Selector使用详解,使用CSS的Selector注意事项有哪些,下面就是实战案例,一起来看一下。 CSS1 中定义的选择器 类型选择器 用于选择指定类型的元素(其实他就是 html 标签选择器),常见用法如下: body { /*对 body 元素定义样式*/}body,…

    2025年12月24日
    000
  • CSS的checkbox效果使用详解

    这次给大家带来CSS的checkbox效果使用详解,使用CSS的checkbox注意事项有哪些,下面就是实战案例,一起来看一下。 实现思路 纯css实现的主要手段是利用label标签的模拟功能。label的for属性可以关联一个具体的input元素,即使这个input本身不可被用户可见,有个与它对应…

    好文分享 2025年12月24日
    000
  • 用css3画个同心圆

    这次给大家带来用css3画个同心圆,用css3画个同心圆的注意事项有哪些,下面就是实战案例,一起来看一下。 基本思路 首先你得画三个圆吧,那三个圆怎么重叠到一块呢?这个就得靠-margin来控制了。 css #t1 { float:left; width:150px; height:150px; b…

    2025年12月24日
    000
  • css3取消上下边的列表间隔线

    这次给大家带来css3取消上下边的列表间隔线,css3取消上下边的列表间隔线的注意事项有哪些,下面就是实战案例,一起来看一下。 效果图:   方法一:通用兄弟选择器( ~ ) Document ul {margin: 0; padding: 0;} li { list-style: none; he…

    2025年12月24日
    000
  • 用CSS将网站变黑白

    这次给大家带来用CSS将网站变黑白,用CSS将网站变黑白的注意事项有哪些,下面就是实战案例,一起来看一下。 方法如下: 这段CSS代码可以变网页为黑白,将代码加到CSS最顶端就可以实现素装。 html{filter: grayscale(100%);-webkit-filter: grayscale…

    好文分享 2025年12月24日
    000
  • 用CSS将网页变黑白

    这次给大家带来用CSS将网页变黑白,用CSS将网页变黑白的注意事项有哪些,下面就是实战案例,一起来看一下。 方法如下: 这段CSS代码可以变网页为黑白,将代码加到CSS最顶端就可以实现素装。 html{filter: grayscale(100%);-webkit-filter: grayscale…

    好文分享 2025年12月24日
    000
  • css3的移动属性

    这次给大家带来css3的移动属性,使用css3移动属性的注意事项有哪些,下面就是实战案例,一起来看一下。 transform功能 放缩 使用sacle方法实现文字或图像的放缩处理,在参数中指定缩放倍率,比如sacle(0.5)表示缩小50%,例子如下: scale方法使用示例 p { width: …

    2025年12月24日 好文分享
    000
  • CSS设置Checkbox复选框的样式

    这次给大家带来CSS设置Checkbox复选框的样式,CSS设置Checkbox复选框样式的注意事项有哪些,下面就是实战案例,一起来看一下。 首先,需要添加一段CSS隐藏所有的Checkbox复选框,下面我们会改变它的外观。要做到点需要添加一段代码到你的CSS文件中。 隐藏掉所有的Checkbox复…

    2025年12月24日 好文分享
    000
  • 用CSS3实现无限循环的无缝滚动效果

    这次给大家带来用CSS3实现无限循环的无缝滚动效果,CSS3实现无限循环的无缝滚动效果注意事项有哪些,下面就是实战案例,一起来看一下。 有时候在页面的某个模块中,需要无限循环的滚动一些消息。那么如果我们用js实现无缝衔接滚动的思路是什么呢(比如我们这个模块是向上滚动的)? 克隆A一份完全一样的数据B…

    2025年12月24日
    000
  • 用CSS3实现发光方格边框

    这次给大家带来用CSS3实现发光方格边框,用CSS3实现发光方格边框的注意事项有哪些,下面就是实战案例,一起来看一下。 本文介绍的是一个使用伪元素来实现边框逐渐发光的代码,主要用到scale和opacity这两个属性。下面来看看详细的介绍: 效果图如下: HTML代码: @@##@@ 前端开发博客 …

    2025年12月24日
    000
  • 使用CSS3制作进度条

    这次给大家带来使用css3制作进度条,使用css3制作进度条的注意事项有哪些,下面就是实战案例,一起来看一下。 这里只是一个小demo,一个用CSS3写的进度条。 如图所示: 具体代码如下: new document .process-bar{ width:100px; display:inline…

    2025年12月24日
    000
  • CSS做出鼠标上移图标旋转

    这次给大家带来css做出鼠标上移图标旋转,实现鼠标上移图标旋转的注意事项有哪些,下面就是实战案例,一起来看一下。 鼠标上移图标旋转效果在企业的项目中经常会使用到,特别是顶部导航栏,比如: 接下来就是要使用css实现鼠标上移图标旋转效果。 p,img,body{ margin: 0; padding:…

    2025年12月24日
    000
  • CSS与Sass开发规范

    这次给大家带来CSS与Sass开发规范,使用CSS与Sass开发规范的注意事项有哪些,下面就是实战案例,一起来看一下。 ID and class naming ID和class(类)名总是使用可以反应元素目的和用途的名称,或其他通用名称。代替表象和晦涩难懂的名称。 应该首选具体和反映元素目的的名称,…

    好文分享 2025年12月24日
    000
  • CSS实现带箭头流程可见进度条

    这次给大家带来CSS实现带箭头流程可见进度条,CSS实现带箭头流程可见进度条的注意事项有哪些,下面就是实战案例,一起来看一下。 首先写出一个基本的样式。 .cssNav li{ padding: 0px 20px; line-height: 40px; background: #50abe4; di…

    2025年12月24日 好文分享
    000
  • CSS3中display属性布局详解

    这次给大家带来CSS3中display属性布局详解,CSS3中display属性布局的注意事项有哪些,下面就是实战案例,一起来看一下。 最近在学习微信小程序,在设计首页布局的时候,新认识了一种布局方式display:flex .container { display: flex; flex-dire…

    2025年12月24日
    000
  • 在CSS中设置透明度的俩种方法

    这次给大家带来在CSS中设置透明度的俩种方法,在CSS中设置透明度的注意事项有哪些,下面就是实战案例,一起来看一下。 1.使用rgba设置背景色的透明 效果如下: 你好啊! body { background-color:red;}#box{ width:200px; height:200px; m…

    好文分享 2025年12月24日
    000
  • 用CSS实现JS的效果

    这次给大家带来用CSS实现JS的效果,用CSS实现JS的注意事项有哪些,下面就是实战案例,一起来看一下。 1. 纯CSS Tooltip  许多网站还是在使用JavaScript来创建Tooltip效果,但实际上通过CSS能更简单的实现。最简单的方法是在你的HTML代码中添加一个带有提示文本的属性,…

    2025年12月24日
    000
  • CSS实现自适应导航菜单

    这次给大家带来CSS实现自适应导航菜单,CSS实现自适应导航菜单的注意事项有哪些,下面就是实战案例,一起来看一下。 以下是一个简单实例,可以通过学习了解响应工菜单的制作。 html Portfolio Illustration Web Design Print Media Graphic Desig…

    好文分享 2025年12月24日
    000

发表回复

登录后才能评论
关注微信