Skip to content

TreeView API

API reference docs for the React TreeView component. Learn about the props, CSS, and other APIs of this exported module.

Demos

For examples and details on the usage of this React component, visit the component demo pages:

Import

import TreeView from '@mui/lab/TreeView';
// or
import { TreeView } from '@mui/lab';
You can learn about the difference by reading this guide on minimizing bundle size.

Props

Props of the native component are also available.

NameTypeDefaultDescription
childrennode
The content of the component.
classesobject
Override or extend the styles applied to the component. See CSS API below for more details.
defaultCollapseIconnode
The default icon used to collapse the node.
defaultEndIconnode
The default icon displayed next to a end node. This is applied to all tree nodes and can be overridden by the TreeItem icon prop.
defaultExpandedArray<string>[]
Expanded node ids. (Uncontrolled)
defaultExpandIconnode
The default icon used to expand the node.
defaultParentIconnode
The default icon displayed next to a parent node. This is applied to all parent nodes and can be overridden by the TreeItem icon prop.
defaultSelectedArray<string>
| string
[]
Selected node ids. (Uncontrolled) When multiSelect is true this takes an array of strings; when false (default) a string.
disabledItemsFocusableboolfalse
If true, will allow focus on disabled items.
disableSelectionboolfalse
If true selection is disabled.
expandedArray<string>
Expanded node ids. (Controlled)
idstring
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.
multiSelectboolfalse
If true ctrl and shift will trigger multiselect.
onNodeFocusfunc
Callback fired when tree items are focused.

Signature:
function(event: React.SyntheticEvent, value: string) => void
event: The event source of the callback Warning: This is a generic event not a focus event.
value: of the focused node.
onNodeSelectfunc
Callback fired when tree items are selected/unselected.

Signature:
function(event: React.SyntheticEvent, nodeIds: Array<string> | string) => void
event: The event source of the callback
nodeIds: Ids of the selected nodes. When multiSelect is true this is an array of strings; when false (default) a string.
onNodeTogglefunc
Callback fired when tree items are expanded/collapsed.

Signature:
function(event: React.SyntheticEvent, nodeIds: array) => void
event: The event source of the callback.
nodeIds: The ids of the expanded nodes.
selectedArray<string>
| string
Selected node ids. (Controlled) When multiSelect is true this takes an array of strings; when false (default) a string.
sxArray<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.

The ref is forwarded to the root element.

Theme default props

You can use MuiTreeView to change the default props of this component with the theme.

CSS

Rule nameGlobal classDescription
root.MuiTreeView-rootStyles applied to the root element.

You can override the style of the component using one of these customization options: