elementui进度条Progress组件

一、Progress组件

二、各部分代码

1.html代码

复制代码
<div>
  <div class="showprogress" v-for="item in regions" :key="item.name">
    <span>{{ item.name }}</span>
    <el-progress :percentage="percentage(item.count, totalCount)" :format="formatCount(item.count)" :color="customColorMethod">
     </el-progress>
   </div>
</div>

使用v-for指令遍历regions数组,为每个区域创建一个进度条显示。

使用<el-progress>组件(Element UI库中的进度条组件)来显示进度。

:percentage:计算并绑定每个进度条的百分比。

:format:自定义进度条上显示的文本。

:color="customColors":绑定进度条的颜色。

2.部分CSS代码

复制代码
.showprogress{
  display: flex;
  justify-content: space-around;
  align-items: center;
                        
  span {
    width: 50px;
    font-size: 12px;
    color: #8CBAEE;
  }
  /deep/.el-progress__text {
    font-size: 12px !important;
    color: #8CBAEE;
  }
}

regions数组:定义了名称及其对应的count值,可动态获取数据。

totalCount:定义了用于计算百分比的总数。

percentage方法:接受两个参数(counttotal),计算并返回百分比。

formatCount方法:常见的做法是直接显示百分比或者格式化后的百分比字符串。

customColorMethod方法:根据进度百分比返回不同的颜色。

3.js代码

复制代码
  data() {
    return {
      regions: [
        { name: "大足区", count: 80 },
        { name: "秀山县", count: 100 },
        { name: "涪陵区", count: 160 },
        { name: "万州区", count: 40 },
        { name: "忠县", count: 200 }
      ],
      totalCount: 200
    };
  },
 methods: {
    percentage(count, total) {
      return (count / total) * 100;
    },
    formatCount(count) {
      return percentage => {
        return `${count}`; // 直接返回条数
      };
    },
    customColorMethod(percentage) {
      if (percentage < 20) {
        return "#8C39A1";
      } else if (percentage < 40) {
        return "#04FCFC";
      } else if (percentage < 60) {
        return "#7C3DFD";
      }else if (percentage < 80) {
        return "#01A4E7"
      }else {
        return "#6f7ad3";
      }
     },
   },
 }

以上是一个简单的进度条展示样式,实现其他样式需细节上修改一些。

若文章对你有帮助,点赞、收藏加关注吧!

相关推荐
candyTong2 分钟前
一觉醒来,大模型就帮我排查完页面性能问题
前端·javascript·架构
玩嵌入式的菜鸡1 小时前
网页访问单片机设备---基于mqtt
前端·javascript·css
前端一小卒1 小时前
我用 Claude Code 的 Superpowers 技能链写了个服务,部署前差点把服务器搞炸
前端·javascript·后端
豹哥学前端5 小时前
用猜数字游戏,一口气掌握 JavaScript 核心知识点(附完整代码)
前端·javascript
忆往wu前6 小时前
从0到1一步步拆解搭建,梳理一个 Vue3 简易图书后台全开发流程
前端·javascript·vue.js
shao9185166 小时前
第3章(2)——使用Gradio JavaScript Client
javascript·node.js·cdn·gradio·job·events·playcode
光影少年6 小时前
大屏页面,一次多个请求,请求加密导致 点击 全局时间选择器 时出现卡顿咋解决(面板收起会延迟1~2秒)
前端·javascript·vue.js·学习·前端框架·echarts·reactjs
Mr.mjw6 小时前
vue中封装一个环形进度条组件,根据外部盒子大小自适应变化
前端·javascript·vue.js
无心使然6 小时前
Openlayers调用ArcGis影像服务之一动态地图、地图切片(/exportImage)
前端·javascript·数据可视化
像我这样帅的人丶你还7 小时前
前端监控体系与实践(二):全局监控
前端·javascript·vue.js