SimpleTreeView API
API reference docs for the React SimpleTreeView component. Learn about the props, CSS, and other APIs of this exported module.
Demos
Import
import { SimpleTreeView } from '@mui/x-tree-view/SimpleTreeView';
// or
import { SimpleTreeView } from '@mui/x-tree-view';
// or
import { SimpleTreeView } from '@mui/x-tree-view-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 | 
|---|---|---|---|
| apiRef | { current?: { focusItem: func, getItem: func, getItemDOMElement: func, getItemOrderedChildrenIds: func, getItemTree: func, getParentId: func, setIsItemDisabled: func, setItemExpansion: func, setItemSelection: func } } | - | The ref object that allows Tree View manipulation. Can be instantiated with  | 
| checkboxSelection | bool | false | If  | 
| children | node | - | The content of the component. | 
| classes | object | - | Override or extend the styles applied to the component. See CSS classes API below for more details. | 
| defaultExpandedItems | Array<string> | [] | Expanded item ids. Used when the item's expansion is not controlled. | 
| defaultSelectedItems | any | [] | Selected item ids. (Uncontrolled) When  | 
| disabledItemsFocusable | bool | false | If  | 
| disableSelection | bool | false | If  | 
| expandedItems | Array<string> | - | Expanded item ids. Used when the item's expansion is controlled. | 
| expansionTrigger | 'content' | 'iconContainer' | 'content' | The slot that triggers the item's expansion when clicked. | 
| id | string | - | This prop is used to help implement the accessibility logic. If you don't provide this prop. It falls back to a randomly generated id. | 
| itemChildrenIndentation | number | string | 12px | Horizontal indentation between an item and its children. Examples: 24, "24px", "2rem", "2em". | 
| multiSelect | bool | false | If  | 
| onExpandedItemsChange | func | - | Callback fired when Tree Items are expanded/collapsed. Signature: function(event: React.SyntheticEvent, itemIds: array) => void
 | 
| onItemClick | func | - | Callback fired when the  Signature: function(event: React.MouseEvent, itemId: string) => void
 | 
| onItemExpansionToggle | func | - | Callback fired when a Tree Item is expanded or collapsed. Signature: function(event: React.SyntheticEvent | null, itemId: array, isExpanded: array) => void
 | 
| onItemFocus | func | - | Callback fired when a given Tree Item is focused. Signature: function(event: React.SyntheticEvent | null, itemId: string) => void
 | 
| onItemSelectionToggle | func | - | Callback fired when a Tree Item is selected or deselected. Signature: function(event: React.SyntheticEvent, itemId: array, isSelected: array) => void
 | 
| onSelectedItemsChange | func | - | Callback fired when Tree Items are selected/deselected. Signature: function(event: React.SyntheticEvent, itemIds: Array
 | 
| selectedItems | any | - | Selected item ids. (Controlled) When  | 
| selectionPropagation | { descendants?: bool, parents?: bool } | { parents: false, descendants: false } | When  | 
| slotProps | object | - | The props used for each component slot. | 
| slots | object | - | Overridable component slots. See Slots API below for more details. | 
| sx | Array<func | object | bool> | func | object | - | The system prop that allows defining system overrides as well as additional CSS styles. See the `sx` page for more details. | 
ref is forwarded to the root element.Theme default props
You can use MuiSimpleTreeView to change the default props of this component with the theme.
| Slot name | Class name | Default component | Description | 
|---|---|---|---|
| root | .MuiSimpleTreeView-root | SimpleTreeViewRoot | Element rendered at the root. | 
| collapseIcon | The default icon used to collapse the item. | ||
| expandIcon | The default icon used to expand the item. | ||
| endIcon | The default icon displayed next to an end item. This is applied to all Tree Items and can be overridden by the TreeItem iconslot prop. | 
These class names are useful for styling with CSS. They are applied to the component's slots when specific states are triggered.
| Class name | Rule name | Description | 
|---|---|---|
| .MuiSimpleTreeView-item | item | Styles applied to the item's root element. | 
| .MuiSimpleTreeView-itemCheckbox | itemCheckbox | Styles applied to the item's checkbox element. | 
| .MuiSimpleTreeView-itemContent | itemContent | Styles applied to the item's content element. | 
| .MuiSimpleTreeView-itemGroupTransition | itemGroupTransition | Styles applied to the item's transition element. | 
| .MuiSimpleTreeView-itemIconContainer | itemIconContainer | Styles applied to the item's icon container element icon. | 
| .MuiSimpleTreeView-itemLabel | itemLabel | Styles applied to the item's label element. | 
You can override the style of the component using one of these customization options:
- With a global class name.
- With a rule name as part of the component's styleOverridesproperty in a custom theme.
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.