This content originally appeared on DEV Community and was authored by Shuvo
Sometimes your list may have a sublist inside it which again may have another sublist in it.
In that case simple loop won't work. You have to use recursion.
So let's see how we can render recursive list using React JS.
Since react supports JSX and we can use regular JavaScript functions so we can simply use a recursive function.
//App.js
function App(){
const list = [
{ type: "item", title: "Wakeup", color: "blue" },
{ type: "item", title: "Get Fresh", color: "blue" },
{ type: "item", title: "Study", color: "blue" },
{
type: "list",
items: [
{ type: "item", title: "Study JavaScript", color: "green" },
{ type: "item", title: "Study OOP", color: "green" },
{
type: "list",
items: [
{ type: "item", title: "Make game using OOP", color: "red" }
]
},
{ type: "item", title: "Study NodeJs", color: "green" },
]
}
]
function renderList(list){
const listTree = list.map(item => {
if(item.type == "item"){
return (
<div className="list-item">
<span className="border" style={{background: item.color}}></span>
<span className="title">{ item.title }</span>
</div>
)
}else{
return (
<div className="list">
{ renderList(item.items) }
</div>
)
}
})
return (
<div className="list">
{ listTree }
</div>
)
}
return (
<div>
<h1>My Nested ToDo List-</h1>
{ renderList(list) }
</div>
)
}
export default App
Now depending on how you style it in CSS it should look something like this.
Now let's see how to render recursive list in Vue JS.
Now we can't use recursive JavaScript function in Vue like we did in react but We can use recursive component.
To be able to use component recursively it must have a name properly!!!
App.vue
<template>
<div>
<h1>My Nested ToDo List-</h1>
<RenderList :list="list" />
</div>
</template>
<script>
import RenderList from "./components/RenderList.vue"
export default {
components: {
RenderList
},
data: () => ({
list: [
{ type: "item", title: "Wakeup", color: "blue" },
{ type: "item", title: "Get Fresh", color: "blue" },
{ type: "item", title: "Study", color: "blue" },
{
type: "list",
items: [
{ type: "item", title: "Study JavaScript", color: "green" },
{ type: "item", title: "Study OOP", color: "green" },
{
type: "list",
items: [
{ type: "item", title: "Make game using OOP", color: "red" }
]
},
{ type: "item", title: "Study NodeJs", color: "green" },
]
}
]
})
}
</script>
RenderList.vue
<template>
<div class="list">
<div v-for="item in list" :key="item.title" :class="{'list': item.type == 'list', 'list-item': item.type == 'item'}">
<span v-if="item.type == 'item'" class="border" :style="{background: item.color}"></span>
<span v-if="item.type == 'item'" class="title">{{ item.title }}</span>
<RenderList v-if="item.type == 'list'" :list="item.items" />
</div>
</div>
</template>
<script>
export default {
name: "RenderList",
props: ['list']
}
</script>
Again depending on how you style it in CSS it should look something like this.
Make sure to check out my other articles and YouTube channel.

This content originally appeared on DEV Community and was authored by Shuvo

Shuvo | Sciencx (2021-10-28T09:52:52+00:00) Recursive list rendering with React and Vue. Retrieved from https://www.scien.cx/2021/10/28/recursive-list-rendering-with-react-and-vue/
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.