vue echarts饼状图内部显示百分比

导读:本篇文章讲解 vue echarts饼状图内部显示百分比,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

实现效果:
在这里插入图片描述
1.首先 在components下面新建一个capacityPieChart.vue 组件页面
在这里插入图片描述
注意:因为我这边饼图需要自适应以及饼图是有多个 需要循环展示 所以引入了两个方法~

//饼状图
<template>
  <div
    :class="className" :style="{ height: height, width: width }" style="margin-top: 20px"
  />
</template>
<script>
require("echarts/theme/macarons"); // echarts theme
import { debounce } from "@/utils";
export default {
  props: {
    caPieItems: Object,
    className: {
      type: String,
      default: "chart",
    },
    width: {
      type: String,
      default: "100%",
    },
    height: {
      type: String,
      default: "300px",
    },
  },
  data() {
    return {
      chart: null,
      optionsData: [],
      opinionName: ["已使用", "未使用"],
    };
  },
  mounted() {
    this.initChart();
    this.__resizeHandler = debounce(() => {
      if (this.chart) {
        this.chart.resize();
      }
    }, 100);
    window.addEventListener("resize", this.__resizeHandler);
  },
  beforeDestroy() {
    if (!this.chart) {
      return;
    }
    window.removeEventListener("resize", this.__resizeHandler);
    this.chart.dispose();
    this.chart = null;
  },
  methods: {
    initChart() {
      this.changeData();
      console.log(this.optionsData, "this.caPieItems");
      this.chart = this.$echarts.init(this.$el, "macarons");
      this.chart.setOption({
        color: ["#A4B6C9", "#4E7095"] /*饼状图的颜色*/,
        tooltip: {
          trigger: "item",
          formatter: "{b}({d}%)" /*饼状图触碰之后显示的注释文字*/,
        },
        legend: {
          left: "center" /*标签文字排成一行*/,
          y: "bottom" /*在垂直方向上的底部*/,
          data: this.opinionName,
          textStyle: {
            //图例文字的样式
            color: "#fff",
            fontSize: 16,
          },
        },

        series: [
          {
            type: "pie", //饼状图
            center: ["50%", "40%"], //显示位置
            name: "",
            type: "pie",
            radius: ["0%", "60%"] /*空心圆的占比*/,
            data: this.optionsData,
            itemStyle: {
              emphasis: {
                shadowBlur: 10,
                shadowOffsetX: 0,
                shadowColor: "rgba(0, 0, 0, 0.5)",
              },
              normal: {
                borderWidth: 2 /*隔开的白色边界*/,
                borderColor: "#fff" /*border*/,
                // labelLine :{show:true}
              },
            },

            avoidLabelOverlap: false,
            label: {
              normal: {
                show: true,
                position: "inner",
                textStyle: {
                  fontWeight: 200,
                  fontSize: 20, //文字的字体大小
                },
                formatter: "{d}%" /*饼状图内显示百分比*/,
                // data:['40%','60%'],
              },

              emphasis: {
                show: false /*空心文字出现*/,
              },
            },
            labelLine: {
              normal: {
                show: false,
              },
            },
          },
        ],
      });
    },
    // 处理数据
    changeData() {
      if (this.caPieItems) {
        this.optionsData = [
          {
            value: this.caPieItems.usedPosCount,
            name: "已使用",
          },
          {
            value: this.caPieItems.totalPosCount - this.caPieItems.usedPosCount,
            name: "未使用",
          },
        ];
      }
    },
  },
};
</script>

页面使用:
在这里插入图片描述

   <!-- 饼图 -->
<template>
 <capacityPieChart :caPieItems="item" />
</template>

item:是接口返回的数据 传给饼图

<script>
import capacityPieChart from "../../../components/Echarts/capacityPieChart.vue";
</script>
components: {
    capacityPieChart,
  },

参考文章:https://blog.csdn.net/qq_40693615/article/details/103407151

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/79287.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!