echarts进度条

<template>
  <div :id="id" class="main" :style="{ width: width, height: height }" :ref="id"></div>
</template>

<script>
import * as echarts from "echarts";
export default {
  name: "roseChart",
  data() {
    return {
      myEchart: null,
      name: "苹果",
      value: 0,
      value1: 10
    };
  },
  props: {
    width: {
      type: String,
      default: "100%"
    },
    height: {
      type: String,
      default: "70px"
    }, // 数据(数组)
    typeAnalysisData: {
      type: Array,
      default: () => []
    },
    id: {
      type: String,
      default: "roseChart"
    } // 是否显示提示(方框)
  },
  methods: {
    drawChart() {
      let timer = null;
      timer = setTimeout(() => {
        if (
          this.myEchart != null &&
          this.myEchart != "" &&
          this.myEchart != undefined
        ) {
          this.myEchart.dispose(); //销毁
        }
        if (!this.$refs[this.id]) return;
        this.myEchart = echarts.init(this.$refs[this.id]);
        let option = {
          // backgroundColor: "#1B232E",
          grid: {
            left: "10px",
            right: "10px",
            bottom: "40px"
          },
          xAxis: {
            show: false,
            type: "value",
            boundaryGap: [0, 0],
            max: 100
          },
          yAxis: {
            type: "category",
            axisTick: "none",
            axisLine: "none",
            show: true,
            position: "right",
            axisLabel: {
              // 后面文字位置
              padding: [-35, 5, 0, 0],
              align: "right",
              verticalAlign: "top",
              textStyle: {
                color: "#fff",
                fontSize: 12
              },
              formatter: this.value1 + "家"
            },
            data: [this.value]
          },
          series: [
            {
              // 进度
              data: [{ name: this.name, value: this.value }],
              name: this.name,
              type: "bar",
              barWidth: "24px",
              showBackground: true,
              backgroundStyle: {
                borderRadius: 2,
                // 整个进度条颜色
                // color: "#252F3D",
                // borderColor: "#252F3D",
                // borderWidth:5,
                opacity: 1
              },
              itemStyle: {
                color: {
                  x: 1,
                  y: 0,
                  x2: 0,
                  y2: 0,
                  colorStops: [
                    {
                      offset: 0,
                      color: "#2AA9D9" // 0% 处的颜色
                    },
                    {
                      offset: 1,
                      color: "#2AA9D9"
                    }
                  ]
                },
                borderRadius: 2
              },
              label: {
                show: true,
                position: "insideTopLeft",
                fontSize: 12,
                fontFamily: "Source Han Sans CN-Regular",
                fontWeight: 400,
                color: "#FFFFFF",
                // 前面文字位置
                padding: [-25, 0, 0, 0],
                formatter: "{b}"
              },
              emphasis: {
                disabled: true
              },
              markPoint: {
                symbol:
                  "image://",
                symbolSize: [30, 48],
                label: { show: false },
                symbolOffset: [0, 0],
                data: [{ name: "最大值", type: "max" }]
              }
            }
          ]
        };

        this.myEchart.setOption(option);
      }, 500);
    }
  },
  mounted() {
    this.drawChart();
    window.addEventListener("resize", this.drawChart);
  },
  watch: {
    typeAnalysisData: {
      handler(newName, oldName) {
        this.$nextTick(() => {
          this.drawChart();
          window.addEventListener("resize", this.drawChart);
        });
      },
      deep: true
    }
  },
  destroyed() {
    window.removeEventListener("resize", this.drawChart);
  }
};
</script>
<style lang="scss" scoped>
</style>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值