Skip to content

Stacked Bar Chart

Examples

Basic Example

vue
<script setup>
const data = [
  {
    name: 2021,
    data: {
      Taylor: 81,
      Clark: 78,
      Martin: 75,
      Perez: 80,
      Lewis: 86,
    },
  },
  {
    name: 2022,
    data: {
      Taylor: 51,
      Clark: 88,
      Martin: 82,
      Perez: 83,
      Lewis: 61,
    },
  },
  {
    name: 2023,
    data: {
      Taylor: 81,
      Clark: 87,
      Martin: 57,
      Perez: 82,
      Lewis: 68,
    },
  },
]
</script>

<template>
  <div
    v-ec="['barStack', data]"
    style="width: 100%; height: 300px; padding-top: 15px;"
  />
</template>

Configured Example

vue
<script setup>
const data = [
  {
    name: 2021,
    data: {
      Taylor: 81,
      Clark: 78,
      Martin: 75,
      Perez: 80,
      Lewis: 86,
    },
  },
  {
    name: 2022,
    data: {
      Taylor: 51,
      Clark: 88,
      Martin: 82,
      Perez: 83,
      Lewis: 61,
    },
  },
  {
    name: 2023,
    data: {
      Taylor: 81,
      Clark: 87,
      Martin: 57,
      Perez: 82,
      Lewis: 68,
    },
  },
]
</script>

<template>
  <div
    v-ec="[
      'barStack',
      data,
      {
        itemColor: ['#DC3545', '#FFC107', '#0D6EFD'],
        borderRadius: 1000, // or [topLeft, topRight, bottomRight, bottomLeft]
        barMaxWidth: 25,
      },
    ]"
    style="width: 100%; height: 300px; padding-top: 15px;"
  />
</template>

Parameter Descriptions

IndexTypeRequiredDefault ValueDescription
0barStackYes--
1DataYes-Data
2OptionsNodefaultOptionsConfiguration parameters
3EcOptionsNo-ECharts configuration parameters

Default Parameter Values

options

ts
const defaultOptions: Options = {
  itemColor: 'auto',
  borderRadius: 0,
  showLabel: true,
}

Parameter Types

Data

ts
/**
 * @example
   [
     { name: 2021, data: { A: 81, B: 78, C: 75 } },
     { name: 2022, data: [['A', 38], ['B', 38], ['C', 38]] }
   ]
 */
export type Data = { name: string, data: NumberObject | NumberKeyValuePairArray }[]

Options

ts
export interface Options {
  /**
   * The color of the bar. If `data` passes in an array,
   * different colors can also be defined here by passing in an array.
   *
   * @see https://echarts.apache.org/option.html#series-bar.itemStyle.color
   */
  itemColor?: string | string[]

  /**
   * @see https://echarts.apache.org/option.html#series-bar.barMaxWidth
   */
  barMaxWidth?: number | string

  /**
   * @see https://echarts.apache.org/option.html#series-bar.barMinWidth
   */
  barMinWidth?: number | string

  /**
   * @see https://echarts.apache.org/option.html#series-bar.itemStyle.borderRadius
   */
  borderRadius?: number | [number, number, number, number]

  showLabel?: boolean
}

EcOptions

ts
export type EcOptions = Partial<EChartsOption>

Released under the MIT License.