Bootstrap源码学习笔记之bootstrap进度条
发布时间 - 2026-01-10 22:04:10 点击率:次基本样式

要实现进度条效果要使用两个容器,外容器使用“progress”样式,子容器使用“progress-bar”样式。例如:
<div class="progress"> <div class="progress-bar" style="width:40%"></div> </div>
progress样式主要设置进度条容器的背景色,容器高度、间距等,progress-bar样式设置进度,主要是设置了进度条的背景颜色和过渡效果。实现源码如下:
.progress {
height: 20px;
margin-bottom: 20px;
overflow: hidden;
background-color: #f5f5f5;
border-radius: 4px;
-webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, .1);
box-shadow: inset 0 1px 2px rgba(0, 0, 0, .1);
}
.progress-bar {
float: left;
width: 0;
height: 100%;
font-size: 12px;
line-height: 20px;
color: #fff;
text-align: center;
background-color: #428bca;
-webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .15);
box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .15);
-webkit-transition: width .6s ease;
-o-transition: width .6s ease;
transition: width .6s ease;
}
彩色进度条
在基础的进度条上追加对应的类名即可:
.progress-bar-info:信息进度条,进度条颜色为蓝色
.progress-bar-success:成功进度条,进度条颜色为绿色
.progress-bar-warning:警告进度条,进度条颜色为黄色
.progress-bar-danger:错误进度条,进度条颜色为红色
实现源码如下:
.progress-bar-success {
background-color: #5cb85c;
}
.progress-bar-info {
background-color: #5bc0de;
}
.progress-bar-warning {
background-color: #f0ad4e;
}
.progress-bar-danger {
background-color: #d9534f;
}
条纹进度条
要实现条纹进度条效果只需要在进度条的容器“progress”基础上增加类名“progress-striped”即可。
实现源码如下:
.progress-striped .progress-bar,
.progress-bar-striped {
background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
-webkit-background-size: 40px 40px;
background-size: 40px 40px;
}
.progress-striped .progress-bar-success {
background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
}
.progress-striped .progress-bar-info {
background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
}
.progress-striped .progress-bar-warning {
background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
}
.progress-striped .progress-bar-danger {
background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
background-image: linear-gradient(45deg, rgba(255, 255, 255, .15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .15) 50%, rgba(255, 255, 255, .15) 75%, transparent 75%, transparent);
}
动态条纹进度条
在进度条“progress progress-striped”两个类的基础上再加入“active”类名即可。例如:
<div class="progress progress-striped active"> <div class="progress-bar progress-bar-success" style="width:40%"></div> </div>
实现原理主要通过CSS3的animation来完成。首先通过@keyframes创建了一个progress-bar-stripes的动画,这个动画主要做了一件事,就是改变背景图像的位置,也就是background-position的值。因为条纹进度条是通过CSS3的线性渐变来制作的,而linear-gradient实现的正是对应背景中的背景图片。动画的实现源码如下:
@-webkit-keyframes progress-bar-stripes {
from {
background-position: 40px 0;
}
to {
background-position: 0 0;
}
}
@-o-keyframes progress-bar-stripes {
from {
background-position: 40px 0;
}
to {
background-position: 0 0;
}
}
@keyframes progress-bar-stripes {
from {
background-position: 40px 0;
}
to {
background-position: 0 0;
}
}
调用动画的实现源码如下:
.progress.active .progress-bar,
.progress-bar.active {
-webkit-animation: progress-bar-stripes 2s linear infinite;
-o-animation: progress-bar-stripes 2s linear infinite;
animation: progress-bar-stripes 2s linear infinite;
}
层叠进度条
层叠进度条可以将不同状态的进度条放置在一起,按水平方式排列。例如:
<div class="progress"> <div class="progress-bar progress-bar-success" style="width:20%"></div> <div class="progress-bar progress-bar-info" style="width:10%"></div> <div class="progress-bar progress-bar-warning" style="width:30%"></div> <div class="progress-bar progress-bar-danger" style="width:15%"></div> </div>
我们可以发现,层叠进度条并没有额外的样式代码,之所以这样就能生效是因为在“progress-bar”上有一个左浮动的样式。要注意,层叠进度条宽度之和不能大于100%。
带Label的进度条
要实现带Label的进度条,只需要在进度条中添加你需要的值即可。例如:
<div class="progress"> <div class="progress-bar progress-bar-success" style="width:20%">20%</div> </div>
要是那进度条的值为0%时,可以这么写:
<div class="progress"> <div class="progress-bar" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100">0%</div> </div>
以上所述是小编给大家介绍的 Bootstrap源码学习笔记之bootstrap进度条,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# bootstrap进度条
# Bootstrap每天必学之进度条
# BootStrap初学者对弹出框和进度条的使用感觉
# BootStrap 实现各种样式的进度条效果
# 有趣的bootstrap走动进度条
# bootstrap实现动态进度条效果
# bootstrap多种样式进度条展示
# Bootstrap进度条实现代码解析
# Bootstrap 3 进度条的实现
# Bootstrap进度条学习使用
# Bootstrap实现各种进度条样式详解
# 进度条
# 只需
# 要在
# 小编
# 是因为
# 就能
# 在此
# 基础上
# 上有
# 我们可以
# 要注意
# 给大家
# 一件事
# 再加
# 来完成
# 所述
# 要使
# 给我留言
# 值为
# 感谢大家
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Windows Hello人脸识别突然无法使用
iOS中将个别页面强制横屏其他页面竖屏
Laravel怎么调用外部API_Laravel Http Client客户端使用
Laravel如何使用Eloquent进行子查询
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】
移动端脚本框架Hammer.js
Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】
UC浏览器如何设置启动页 UC浏览器启动页设置方法
Laravel Docker环境搭建教程_Laravel Sail使用指南
Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】
java ZXing生成二维码及条码实例分享
如何在IIS中新建站点并配置端口与IP地址?
Internet Explorer官网直接进入 IE浏览器在线体验版网址
Mybatis 中的insertOrUpdate操作
如何在服务器上配置二级域名建站?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环
Bootstrap整体框架之CSS12栅格系统
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】
js代码实现下拉菜单【推荐】
如何用花生壳三步快速搭建专属网站?
如何在腾讯云服务器快速搭建个人网站?
Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用
Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】
Laravel如何实现用户注册和登录?(Auth脚手架指南)
如何快速上传建站程序避免常见错误?
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
三星、SK海力士获美批准:可向中国出口芯片制造设备
JavaScript模板引擎Template.js使用详解
zabbix利用python脚本发送报警邮件的方法
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
Laravel如何创建自定义Artisan命令?(代码示例)
Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】
Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理
5种Android数据存储方式汇总
如何快速建站并高效导出源代码?
Laravel如何与Docker(Sail)协同开发?(环境搭建教程)
郑州企业网站制作公司,郑州招聘网站有哪些?
Laravel如何实现密码重置功能_Laravel密码找回与重置流程
javascript中的try catch异常捕获机制用法分析
网站制作壁纸教程视频,电脑壁纸网站?
消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工
Laravel如何创建自定义Facades?(详细步骤)
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程
Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南
Bootstrap CSS布局之列表
JavaScript如何实现倒计时_时间函数如何精确控制

