Use a recursive Blazor component to render a TreeView
I recently ran into a requirement to show a nested list of items in a menu for a “code explorer” component:
There’s no concrete limit to how deep this list can go (each item can have its own list of items and so on and so forth).
Here’s the data that drives this UI:
Notice how each instance of NodeDTO
can have its own list of NodeDTO
, hence the potentially infinite tree depth.
So how can we render this in Blazor?
Well it turns out Blazor can handle a little bit of recursion, making this relatively straightforward.
First we’ll want a root component, to act as the starting point for the TreeView.
GetCourseResponse
contains the root node (the toppest of the top level nodes!)
All the magic happens in the Node
component.
Node.razor
The first step is to render the UI for the current node (in this case, a button).
The next step is to loop over each of the sub nodes and render instances of the Node
component for each one.
NOTE
Make sure you forward any parameters along to the nested Node
components:
If you forgot to set the CourseNode
and OnNodeSelected
parameters here, children of this node won’t have the data or event callbacks they need to function properly.
With that, we have a potentially infinite depth Tree View component.
From here we can extend this to handle things like showing different icons for different node types, simply by making changes to that Node
component.