Charts - Bars
Bar charts express quantities through a bar's length, using a common baseline.
Basics
Bar charts series should contain a data property containing an array of values.
You can specify bar ticks with the xAxis prop.
This axis might have scaleType='band' and its data should have the same length as your series.
Using a dataset
If your data is stored in an array of objects, you can use the dataset helper prop.
It accepts an array of objects such as dataset={[{x: 1, y: 32}, {x: 2, y: 41}, ...]}.
You can reuse this data when defining the series and axis, thanks to the dataKey property.
For example xAxis={[{ dataKey: 'x'}]} or series={[{ dataKey: 'y'}]}.
- London
- Paris
- New York
- Seoul
Bar size
You can define bar dimensions with categoryGapRatio and barGapRatio properties.
The categoryGapRatio defines the gap between two categories.
The ratio is obtained by dividing the size of the gap by the size of the category (the space used by bars).
The barGapRatio defines the gap between two bars of the same category.
It's the size of the gap divided by the size of the bar.
So a value of 1 will result in a gap between bars equal to the bar width.
And a value of -1 will make bars overlap on top of each other.
Netflix balance sheet
import { BarChart } from '@mui/x-charts/BarChart';
<BarChart
  // ...
  xAxis={[
    {
      scaleType: 'band',
      data: ['Page 1', 'Page 2', 'Page 3'],
      categoryGapRatio: 0.3,
      barGapRatio: 0.1,
    },
  ]}
/>Playground
Stacking
Each bar series can get a stack property expecting a string value.
Series with the same stack will be stacked on top of each other.
Netflix balance sheet
Stacking strategy
You can use the stackOffset and stackOrder properties to define how the series will be stacked.
By default, they are stacked in the order you defined them, with positive values stacked above 0 and negative values stacked below 0.
For more information, see stacking docs.
Layout
Bar direction
Bar charts can be rendered with a horizontal layout by providing the layout="horizontal" prop.
If you're using composition, you should set the property layout: 'horizontal' to each bar series object.
- Seoul rainfall
Tick placement
When using a "band" scale, the axis has some additional customization properties about the tick position.
- tickPlacementfor the position of ticks
- tickLabelPlacementfor the position of the label associated with the tick
You can test all configuration options in the following demo:
- Seoul rainfall
Minimum bar size
You can set a minimum bar size with the minBarSize property.
This property is useful when you want to ensure that bars are always visible, even when the data is sparse or the chart is small.
The minBarSize property is ignored if the series value is null or 0.
It also doesn't work with stacked series.
minBarSize: 10px
Log scale
A bar chart renders a bar from 0 to the value of a data point. However, the logarithm of zero is undefined, meaning that a y-axis with a log scale cannot plot the bar.
You can work around this limitation by using a symlog scale.
Customization
Grid
You can add a grid in the background of the chart with the grid prop.
See Axis—Grid documentation for more information.
- Seoul rainfall
Color scale
As with other charts, you can modify the series color either directly, or with the color palette.
You can also modify the color by using axes colorMap which maps values to colors.
The bar charts use by priority:
- The value axis color
- The band axis color
- The series color
Learn more about the colorMap properties in the Styling docs.
<BarChart
  /* ... */
  xAxis={[{
    colorMap: {
      type: 'piecewise',
      thresholds: [new Date(2021, 1, 1), new Date(2023, 1, 1)],
      colors: ['blue', 'red', 'blue'],
    }
  }]}
  yAxis={[{}]}
/>Border radius
To give your bar chart rounded corners, you can change the value of the borderRadius property on the BarChart.
It works with any positive value and is properly applied to horizontal layouts, stacks, and negative values.
Border Radius
- High
- Low
<BarChart
  // ...
  borderRadius={10}
/>CSS
You can customize the bar chart elements using CSS selectors.
Each series renders a g element that contains a data-series attribute.
You can use this attribute to target elements based on their series.
Gradients
By default, a gradient's units are set to objectBoundingBox.
When applied to a bar, the gradient stretches to fill the entire size of the bar, regardless of the bar's value.
Alternatively, you can set gradientUnits to userSpaceOnUse, which stretches the gradient to fill the entire size of the chart.
userSpaceOnUse means that the gradient's coordinates are relative to the SVG, meaning that a gradient with x1="0" and x2="100%" stretches across the entire width of the SVG.
This effectively reveals the gradient depending on the bar's value, as the gradient is clipped to the bar's size.
Household Savings in OECD Countries (2016)
Note that, in the example above, there are two gradients:
- The series colorproperty references the gradient withgradientUnits="objectBoundingBox", which is applied to the tooltip, legend, and other elements that reference the series color.
- The bar's fillproperty is overridden using CSS to reference the gradient withgradientUnits="userSpaceOnUse".
The first gradient is used for elements showing the whole gradient, such as tooltips and legend. The second one is shown in the bars themselves that display the part of the gradient that corresponds to their value.
Labels
You can display labels on the bars.
To do so, the BarChart or BarPlot accepts a barLabel prop.
It can either get a function that gets the bar item and some context.
Or you can pass 'value' to display the raw value of the bar.
Custom labels
You can display, change, or hide labels based on conditional logic.
To do so, provide a function to the barLabel.
Labels are not displayed if the function returns null.
In the example we display a 'High' text on values higher than 10, and hide values when the generated bar height is lower than 60px.
- Series A1
- Series A2
- Series B1
You can further customize the labels by providing a component to the barLabel slot.
In the example below, we position the labels above the bars they refer to.
Click event
Bar charts provides two click handlers:
- onItemClickfor click on a specific bar.
- onAxisClickfor a click anywhere in the chart
They both provide the following signature.
const clickHandler = (
  event, // The mouse event.
  params, // An object that identifies the clicked elements.
) => {};
- A
- B
- C
Click on the chart
// Data from item click
// The data will appear here
// Data from axis click
// The data will appear hereIf you're composing a custom component, you can incorporate click events as shown in the code snippet below.
Note that onAxisClick can handle both bar and line series if you mix them.
<ChartContainer onAxisClick={onAxisClick}>
  {/* ... */}
  <BarPlot onItemClick={onItemClick} />
</ChartContainer>
Animation
Chart containers respect prefers-reduced-motion, but you can also disable animations manually by setting the skipAnimation prop to true.
When skipAnimation is enabled, the chart renders without any animations.
// For a single component chart
<BarChart skipAnimation />
// For a composed chart
<ChartContainer>
  <BarPlot skipAnimation />
</ChartContainer>
- series 1
- series 2
Number of items
Number of series
Composition
Use the <ChartDataProvider /> to provide series, xAxis, and yAxis props for composition.
In addition to the common chart components available for composition, you can use the <BarPlot /> component that renders the bars and their labels.
Here's how the Bar Chart is composed:
<ChartDataProvider>
  <ChartsWrapper>
    <ChartsLegend />
    <ChartsSurface>
      <ChartsGrid />
      <g clipPath={`url(#${clipPathId})`}>
        <BarPlot />
        <ChartsOverlay />
        <ChartsAxisHighlight />
      </g>
      <ChartsAxis />
      <ChartsClipPath id={clipPathId} />
    </ChartsSurface>
    <ChartsTooltip />
  </ChartsWrapper>
</ChartDataProvider>
API
See the documentation below for a complete reference to all of the props and classes available to the components mentioned here.