echarts绘制柱状图

<template>
  <div>
    <div>【大区数据信息】</div>
    <div ref="target" class="w-full h-full" ></div>
  </div>
</template>

<script setup>
import { ref, onMounted, watch} from "vue";
import * as echarts from "echarts";
const regions=[
  {
    "id": 1,
    "name": "华北",
    "value": 56
  },
  {
    "id": 2,
    "name": "东北",
    "value": 50
  },
  {
    "id": 3,
    "name": "华东",
    "value": 86
  },
  {
    "id": 4,
    "name": "中南",
    "value": 55
  },
  {
    "id": 5,
    "name": "西南",
    "value": 52
  },
  {
    "id": 6,
    "name": "西北",
    "value": 77
  }
]
// 1.初始化
let myChart = null;
const target = ref(null);
onMounted(() => {
  myChart = echarts.init(target.value);
  renderChart();
});

// 2.构建 option 配置对象
const renderChart = () => {
  const options = {
    // X轴展示数据
    xAxis: {
      show: false, //不显示X
      type: "value", //表示X轴作为数据展示
      max: function (value) {
        return parseInt(value.max * 1.2);
      },
    },
    // Y轴展示数据
    yAxis: {
      type: "category",
      data: regions.map((item) => item.name),
      inverse: true,
      axisLine: { show: false }, //不展示线
      axisTick: { show: false }, //不展示刻度
      axisLabel: { color: "#9eb1c8" },
    },
    // 图标绘制的位置 对应上下左右
    grid: {
      top: 0,
      right: 0,
      bottom: 0,
      left: 0,
      containLabel: true, //计算时包含标签
    },
    // 核心配置
    series: [
      {
        type: "bar",
        data:regions.map((item) => ({
          name: item.name,
          value: item.value,
        })),
        showBackground: true,
        backgroundStyle: {
          color: "rgba(180, 180, 180, 0.2)",
        },
        itemStyle: { //设置柱状图的样式
          color: "#5D98CE",
          barBorderRadius: 5, //圆角
          shadowColor: "rgba(0,0,0,0.3)",
          shadowBlur: 5,
        },
        barWidth: 12,//宽度
        label: { //柱状的刻度
          show: true,
          position: "right", //位置
          textStyle: { //颜色
            color: "#fff",
          },
        },
      },
    ],
  };
  // 3.通过实例.setOptions(option)
  myChart.setOption(options);
};
watch(
  () =>  regions,
  () => renderChart()
);
</script>

<style lang="scss" scoped></style>

在这里插入图片描述

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值