element UI + vue2 + html实现堆叠条形图 - 横向分段器

效果图:

复制代码
<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <!-- import CSS -->
  <link rel="stylesheet" href="https://cdn.staticfile.org/element-ui/2.15.9/theme-chalk/index.css">

</head>
<style>
  .clean-clr-bg {
    background-color:#6f85d4 ;
  }
  .clean-clr {
    color: #6f85d4;
  }

  .custom-segmented-progress {
    position: relative;
    display: flex;
    //align-items: flex-start;
    //flex-direction: column;
  }

  .custom-segmented-progress > div {
    text-align: center; /* 文本居中 */
    color: #fff; /* 文本颜色 */
  }
</style>
<body>
<div id="app">
 
  <div style="margin-bottom: 10px">
    <div class="custom-segmented-progress" style="background-color: #ada9a9">
      <div style="width: 30%;background-color: #00C777">30%</div>
      <div style="width: 30%;background-color: #b0cbc1">30%</div>
    </div>
  </div>
  <br>

  <div
    style="border:1px solid #e2c7c7;border-radius:6px;width: 28%;height:452px;margin-top: 30px;overflow: hidden;padding: 20px;font-size: 12px;max-width: 300px;min-width: 180px;">
    <div style="font-size: 20px;font-weight: bold">最近30天科室收发总数排名</div>

    <div v-for="(segment, index) in segments" :key="index" style="background-color: #fff; ">
      <div style="display: flex;justify-content: space-between;margin-left: 6px;margin-right: 6px;padding-top: 10px;">
        <div>
          <span
            style="display:inline-block;height:16px;width:16px;border: 1px solid #f0ad4e;border-radius: 50%;text-align: center;margin-left: 6px;">{{ index + 1 }}</span><span>儿科</span>
        </div>
        <span>2312</span>
      </div>


      <div class="custom-segmented-progress"
           style="background-color: #f2f2f2;border:0px solid #7b7676;margin-top: 10px">
        <div v-for="(part, pindex) in segment" :key="pindex"
             :style="segmentStyle(part)">{{ part.percentage }}%
        </div>
      </div>

      <br>
    </div>
    <div style="display: flex;justify-content: start">
      <div class="clean-clr"  ><span class="clean-clr-bg"
        style="display:inline-block;height: 10px;width: 10px; margin-right: 10px;border-radius: 50%"> </span>净物总数</div>
      <div style="color: #6f85d4"><span
        style="display:inline-block;height: 10px;width: 10px;background-color: #b2ca4d;margin-right: 10px;border-radius: 50%"> </span>污物总数
      </div>
    </div>
  </div>
</div>
</body>
<script src="https://unpkg.com/vue@2/dist/vue.js"></script>
<script src="https://cdn.staticfile.org/element-ui/2.15.9/index.min.js"></script>
<script>
  Vue.config.productionTip = false //阻止vue在启动时生成生产提示
  const vm = new Vue({
    el: '#app',
    data: {
      message: "好的",
      segments: [
        [{percentage: 30, color: '#6f85d4'}, {percentage: 70, color: '#b2ca4d'}],
        [{percentage: 100, color: '#6f85d4'}],
        [{percentage: 8, color: '#6f85d4'}, {percentage: 30, color: '#b2ca4d'},],
        [{percentage: 70, color: '#b2ca4d'},],
        [{percentage: 30, color: '#6f85d4'}, {percentage: 30, color: '#b2ca4d'},],
      ]
    },
    computed: {},
    components: {},
    props: {},
    methods: {
      segmentStyle(segment) {
        return {
          width: `${segment.percentage}%`,
          backgroundColor: segment.color,
          height: '20px' // 根据需要调整高度
        };
      }
    },
    watch: {},// 监控 data 中的数据变化
    //过滤器
    filters: {},
  })

</script>
</html>
相关推荐
FAQEW2 小时前
若依(RuoYi-Vue)单体架构实战手册:自定义业务模块全流程开发指南
前端·后端·架构·若依二开
神算大模型APi--天枢6462 小时前
合规与高效兼得:国产全栈架构赋能行业大模型定制,从教育到工业的轻量化落地
大数据·前端·人工智能·架构·硬件架构
千寻girling2 小时前
马上元旦节了,手写一个《前端脚手架》庆祝一下 !
前端
嚣张丶小麦兜2 小时前
认识vite
前端·javascript·vue.js
玲小珑3 小时前
请求 ID 跟踪模式:解决异步请求竞态条件
前端
开心_开心急了3 小时前
AI+PySide6实现自定义窗口标题栏目(titleBar)
前端
开心_开心急了3 小时前
Ai加Flutter实现自定义标题栏(appBar)
前端·flutter
布列瑟农的星空3 小时前
SSE与流式传输(Streamable HTTP)
前端·后端
GISer_Jing3 小时前
跨境营销前端AI应用业务领域
前端·人工智能·aigc