BarChart API
API reference docs for the React BarChart component. Learn about the props, CSS, and other APIs of this exported module.
Demos
Import
import { BarChart } from '@mui/x-charts/BarChart';
// or
import { BarChart } from '@mui/x-charts';
// or
import { BarChart } from '@mui/x-charts-pro';Learn about the difference by reading this guide on minimizing bundle size.
Props of the native component are also available.
| Name | Type | Default | Description | 
|---|---|---|---|
| series* | Array<object> | - | The series to display in the bar chart. An array of BarSeriesType objects. | 
| axisHighlight | { x?: 'band' | 'line' | 'none', y?: 'band' | 'line' | 'none' } | - | The configuration of axes highlight. Default is set to 'band' in the bar direction. Depends on  See highlighting docs for more details. | 
| barLabel | 'value' | func | - | If provided, the function will be used to format the label of the bar. It can be set to 'value' to display the current value. | 
| borderRadius | number | - | Defines the border radius of the bar element. | 
| bottomAxis | object | string | xAxisIds[0] The id of the first provided axis | Indicate which axis to display the bottom of the charts. Can be a string (the id of the axis) or an object  | 
| colors | Array<string> | func | blueberryTwilightPalette | Color palette used to colorize multiple series. | 
| dataset | Array<object> | - | An array of objects that can be used to populate series and axes data using their  | 
| disableAxisListener | bool | false | If  | 
| grid | { horizontal?: bool, vertical?: bool } | - | Option to display a cartesian grid in the background. | 
| height | number | - | The height of the chart in px. If not defined, it takes the height of the parent element. | 
| hideLegend | bool | - | If  | 
| highlightedItem | { dataIndex?: number, seriesId?: number | string } | - | The item currently highlighted. Turns highlighting into a controlled prop. | 
| layout | 'horizontal' | 'vertical' | 'vertical' | The direction of the bar elements. | 
| leftAxis | object | string | yAxisIds[0] The id of the first provided axis | Indicate which axis to display the left of the charts. Can be a string (the id of the axis) or an object  | 
| loading | bool | false | If  | 
| margin | { bottom?: number, left?: number, right?: number, top?: number } | object Depends on the charts type. | The margin between the SVG and the drawing area. It's used for leaving some space for extra information such as the x- and y-axis or legend. Accepts an object with the optional properties:  | 
| onAxisClick | func | - | The function called for onClick events. The second argument contains information about all line/bar elements at the current mouse position. Signature: function(event: MouseEvent, data: null | AxisData) => void
 | 
| onHighlightChange | func | - | The callback fired when the highlighted item changes. Signature: function(highlightedItem: HighlightItemData | null) => void
 | 
| onItemClick | func | - | Callback fired when a bar item is clicked. Signature: function(event: React.MouseEvent
 | 
| rightAxis | object | string | null | Indicate which axis to display the right of the charts. Can be a string (the id of the axis) or an object  | 
| skipAnimation | bool | - | If  | 
| slotProps | object | {} | The props used for each component slot. | 
| slots | object | {} | Overridable component slots. See Slots API below for more details. | 
| topAxis | object | string | null | Indicate which axis to display the top of the charts. Can be a string (the id of the axis) or an object  | 
| width | number | - | The width of the chart in px. If not defined, it takes the width of the parent element. | 
| xAxis | Array<{ classes?: object, colorMap?: { colors: Array<string>, type: 'ordinal', unknownColor?: string, values?: Array<Date | number | string> } | { color: Array<string> | func, max?: Date | number, min?: Date | number, type: 'continuous' } | { colors: Array<string>, thresholds: Array<Date | number>, type: 'piecewise' }, data?: array, dataKey?: string, disableLine?: bool, disableTicks?: bool, domainLimit?: 'nice' | 'strict' | func, fill?: string, hideTooltip?: bool, id?: number | string, label?: string, labelFontSize?: number, labelStyle?: object, max?: Date | number, min?: Date | number, position?: 'bottom' | 'top', reverse?: bool, scaleType?: 'band' | 'linear' | 'log' | 'point' | 'pow' | 'sqrt' | 'time' | 'utc', slotProps?: object, slots?: object, stroke?: string, sx?: Array<func | object | bool> | func | object, tickFontSize?: number, tickInterval?: 'auto' | array | func, tickLabelInterval?: 'auto' | func, tickLabelPlacement?: 'middle' | 'tick', tickLabelStyle?: object, tickMaxStep?: number, tickMinStep?: number, tickNumber?: number, tickPlacement?: 'end' | 'extremities' | 'middle' | 'start', tickSize?: number, valueFormatter?: func }> | - | The configuration of the x-axes. If not provided, a default axis config is used. An array of AxisConfig objects. | 
| yAxis | Array<{ classes?: object, colorMap?: { colors: Array<string>, type: 'ordinal', unknownColor?: string, values?: Array<Date | number | string> } | { color: Array<string> | func, max?: Date | number, min?: Date | number, type: 'continuous' } | { colors: Array<string>, thresholds: Array<Date | number>, type: 'piecewise' }, data?: array, dataKey?: string, disableLine?: bool, disableTicks?: bool, domainLimit?: 'nice' | 'strict' | func, fill?: string, hideTooltip?: bool, id?: number | string, label?: string, labelFontSize?: number, labelStyle?: object, max?: Date | number, min?: Date | number, position?: 'left' | 'right', reverse?: bool, scaleType?: 'band' | 'linear' | 'log' | 'point' | 'pow' | 'sqrt' | 'time' | 'utc', slotProps?: object, slots?: object, stroke?: string, sx?: Array<func | object | bool> | func | object, tickFontSize?: number, tickInterval?: 'auto' | array | func, tickLabelInterval?: 'auto' | func, tickLabelPlacement?: 'middle' | 'tick', tickLabelStyle?: object, tickMaxStep?: number, tickMinStep?: number, tickNumber?: number, tickPlacement?: 'end' | 'extremities' | 'middle' | 'start', tickSize?: number, valueFormatter?: func }> | - | The configuration of the y-axes. If not provided, a default axis config is used. An array of AxisConfig objects. | 
ref is forwarded to the root element.Theme default props
You can use MuiBarChart to change the default props of this component with the theme.
| Slot name | Class name | Default component | Description | 
|---|---|---|---|
| axisLabel | ChartsText | Custom component for axis label. | |
| axisLine | 'line' | Custom component for the axis main line. | |
| axisTick | 'line' | Custom component for the axis tick. | |
| axisTickLabel | ChartsText | Custom component for tick label. | |
| bar | BarElementPath | The component that renders the bar. | |
| barLabel | BarLabel | The component that renders the bar label. | |
| legend | DefaultChartsLegend | Custom rendering of the legend. | |
| loadingOverlay | ChartsLoadingOverlay | Overlay component rendered when the chart is in a loading state. | |
| noDataOverlay | ChartsNoDataOverlay | Overlay component rendered when the chart has no data to display. | |
| tooltip | ChartsTooltipRoot | Custom component for the tooltip popper. | 
Source code
If you did not find the information in this page, consider having a look at the implementation of the component for more detail.