基础柱状图

柱状图是一种用于展示离散数据之间比较关系的图表。柱子的长度与类别数据成比例。

要设置柱状图,你需要将 seriestype 设置为 'bar'

[配置项]

简单示例

让我们从一个基础柱状图开始

option = {
  xAxis: {
    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
  },
  yAxis: {},
  series: [
    {
      type: 'bar',
      data: [23, 24, 18, 25, 27, 28, 25]
    }
  ]
};
在线演示

在这个例子中,x 轴是类别类型。因此,你应该为 'xAxis' 定义一些相应的值。同时,y 轴的数据类型是数值类型。y 轴的范围将由 'series' 中的 data 自动生成。

多系列柱状图

你可以使用一个系列来表示一组相关数据。要在同一个图表中显示多个系列,你需要在 series 下添加一个额外的数组。

option = {
  xAxis: {
    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
  },
  yAxis: {},
  series: [
    {
      type: 'bar',
      data: [23, 24, 18, 25, 27, 28, 25]
    },
    {
      type: 'bar',
      data: [26, 24, 18, 22, 23, 20, 27]
    }
  ]
};
在线演示

自定义柱状图

样式

通过使用 'series.itemStyle' 来设置柱状图的样式是一个好主意。样式配置项的描述:

  • 柱子的颜色 ('color');
  • 柱子的轮廓颜色 ('borderColor'),宽度 ('borderWidth'),类型 ('borderType');
  • 柱子的边框圆角 ('barBorderRadius');
  • 透明度 ('opacity');
  • 阴影类型 ('shadowBlur', 'shadowColor', 'shadowOffsetX', 'shadowOffsetY')

这是一个示例

option = {
  xAxis: {
    data: ['A', 'B', 'C', 'D', 'E']
  },
  yAxis: {},
  series: [
    {
      type: 'bar',
      data: [
        10,
        22,
        28,
        {
          value: 43,
          // Specify the style for single bar
          itemStyle: {
            color: '#91cc75',
            shadowColor: '#91cc75',
            borderType: 'dashed',
            opacity: 0.5
          }
        },
        49
      ],
      itemStyle: {
        barBorderRadius: 5,
        borderWidth: 1,
        borderType: 'solid',
        borderColor: '#73c0de',
        shadowColor: '#5470c6',
        shadowBlur: 3
      }
    }
  ]
};
在线演示

在这个例子中,我们通过相应 series'itemStyle' 定义了柱状图的样式。有关完整的配置项及其用法,请查阅配置项手册:series.itemStyle

柱子的宽度和高度

你可以使用 barWidth 来改变柱子的宽度。例如,在下面的例子中,'barWidth' 设置为 '20%'。这表示每个柱子的宽度是类别宽度的 20%。由于每个系列有 5 个数据,20% 的 'barWidth' 表示整个 x 轴的 4%。

option = {
  xAxis: {
    data: ['A', 'B', 'C', 'D', 'E']
  },
  yAxis: {},
  series: [
    {
      type: 'bar',
      data: [10, 22, 28, 43, 49],
      barWidth: '20%'
    }
  ]
};
在线演示

此外,barMaxWidth 限制了柱子的最大宽度。对于一些较小的值,你可以为柱子声明一个最小高度:barMinHeight。当数据对应的柱子高度小于该限制时,ECharts 将使用 'barMinHeight' 作为替换高度。

柱子间距

有两种柱子间距。一种是同一类别下不同系列之间的间距:barGap。另一种是类别之间的间距:barCategoryGap

option = {
  xAxis: {
    data: ['A', 'B', 'C', 'D', 'E']
  },
  yAxis: {},
  series: [
    {
      type: 'bar',
      data: [23, 24, 18, 25, 18],
      barGap: '20%',
      barCategoryGap: '40%'
    },
    {
      type: 'bar',
      data: [12, 14, 9, 9, 11]
    }
  ]
};
在线演示

在这个例子中,barGap'20%'。这意味着同一类别下柱子之间的距离是柱子宽度的 20%。例如,如果我们设置 barCategoryGap'40%',则柱子每一侧的间距将占据类别中的 40% 的位置(与柱子的宽度相比)。

通常,如果设置了 'barGap'barCategoryGap,则不需要明确指定 barWidth。如果你需要确保柱子在图表较大时不会太宽,请尝试使用 barMaxWidth 来限制柱子的最大宽度。

在同一个笛卡尔坐标系中,该属性将被多个柱状图系列共享。要确保它在图表上生效,请在系统的最后一个柱状图系列上设置该属性。

为柱子添加背景色

有时你可能希望更改柱子的背景色。在 ECharts v4.7.0 之后,可以通过 'showBackground' 启用此功能,并通过 'backgroundStyle' 配置。

option = {
  xAxis: {
    type: 'category',
    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
  },
  yAxis: {
    type: 'value'
  },
  series: [
    {
      data: [120, 200, 150, 80, 70, 110, 130],
      type: 'bar',
      showBackground: true,
      backgroundStyle: {
        color: 'rgba(220, 220, 220, 0.8)'
      }
    }
  ]
};
在线演示

贡献者 在 GitHub 上编辑此页面

plainheart plainheartpissang pissang