VUE 無限層級樹形數(shù)據(jù)結(jié)構(gòu)顯示的實現(xiàn)
在做項目中,會遇到一些樹形的數(shù)據(jù)結(jié)構(gòu),常用在左側(cè)菜單導(dǎo)航,或者評論引用等地方,這種數(shù)據(jù)結(jié)構(gòu)有個特點是不知道它會嵌套多少層,所以用template去展示這樣的數(shù)據(jù)時就有點棘手,這篇文章梳理兩種展示這種數(shù)據(jù)結(jié)構(gòu)的方法。
文章中用到的數(shù)據(jù)是下面這個:
mainData: {
value: "root",
children:[{
value: "層級1-1",
children:[{
value: "層級2-1",
children:[{
value: "層級3-1",
children:[]
}]
},{
value: "層級2-2",
children:[]
}]
},{
value: "層級1-2",
children:[]
}]
}
也就是下面這個樣子。

組件遞歸調(diào)用
第一種是組件遞歸調(diào)用自己的方式,創(chuàng)建一個組件,該組件在引用自己去展示children的數(shù)據(jù),子組件如下:
<template>
<div>
<div class="demo">
{{treeData.value}}
<tree-comp v-for="(item, index) in treeData.children" :treeData="item"></tree-comp>
</div>
</div>
</template>
<script>
export default {
name: 'treeComp',
props:{
treeData: {
default: function(){
return {}
}
}
},
mounted(){},
methods:{}
}
</script>
<style lang="less" scoped>
.demo{padding:5px 0;margin:1px 10px;text-align: left;font-size:16px;max-width:500px;border-left:1px dashed #999;
&:before{content:'--';display: inline-block;padding:0 4px;}
}
</style>
然后創(chuàng)建父組件,父組件使用子組件,并將數(shù)據(jù)傳入子組件。
<template>
<tree-comp :treeData="mainData"></tree-comp>
</template>
<script>
export default {
name: 'treeMain',
data () {
return {
mainData: {
value: "root",
children:[
{
value: "層級1-1",
children:[{
value: "層級2-1",
children:[{
value: "層級3-1",
children:[]
}]
},{
value: "層級2-2",
children:[]
}]
},{
value: "層級1-2",
children:[]
}
]
}
}
},
components:{
"tree-comp": () => import('./TreeComp')
},
mounted(){},
methods:{}
}
</script>
關(guān)于遞歸組件的內(nèi)容,在官方文檔里是有提到的-->遞歸組件
使用render方法
除了使用組件的方式,也可以使用vue的render方法,去利用JavaScript 的完全編程的能力,實現(xiàn)遞歸處理樹形數(shù)據(jù),從而展示出無限層級樹。如下:
<template>
<tree-comp :treeData="mainData"></tree-comp>
</template>
<script>
export default {
name: 'treeRender',
data () {
return {
mainData: {
value: "root",
children:[
{
value: "層級1-1",
children:[{
value: "層級2-1",
children:[{
value: "層級3-1",
children:[]
}]
},{
value: "層級2-2",
children:[]
}]
},{
value: "層級1-2",
children:[]
}
]
}
}
},
components:{
treeComp:{
functional: true,
props: {treeData: Object},
render(h, {props: {treeData = {}}}) {
const creatNode = (node)=>{
if(node.children && node.children.length > 0){
let hArr = node.children.map(item=>{
return creatNode(item)
})
return h('div', {class:'demo'}, [node.value, hArr])
}else{
return h('div', {class:'demo'}, [node.value])
}
}
return creatNode(treeData)
},
}
},
mounted(){},
methods:{}
}
</script>
<style lang="less" scoped>
.demo{padding:5px 0;margin:1px 10px;text-align: left;font-size:16px;max-width:500px;border-left:1px dashed #999;
&:before{content:'--';display: inline-block;padding:0 4px;}
}
</style>
其中最核心的就是在render方法里,creatNode方法用遞歸的方式,深度優(yōu)先遍歷樹狀數(shù)據(jù),生成vnode,然后渲染出了頁面。
到此這篇關(guān)于VUE 無限層級樹形數(shù)據(jù)結(jié)構(gòu)顯示的實現(xiàn)的文章就介紹到這了,更多相關(guān)VUE 無限層級樹形結(jié)構(gòu)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
element vue validate驗證名稱重復(fù) 輸入框與后臺重復(fù)驗證 特殊字符 字符長度 及注意事項小結(jié)【實例代碼
這篇文章主要介紹了element vue validate驗證名稱重復(fù) 輸入框與后臺重復(fù)驗證 特殊字符 字符長度 及注意事項小結(jié),本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11
vue element-ui實現(xiàn)input輸入框金額數(shù)字添加千分位
這篇文章主要介紹了vue element-ui實現(xiàn)input輸入框金額數(shù)字添加千分位,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12
vue.js數(shù)據(jù)綁定的方法(單向、雙向和一次性綁定)
本篇文章主要介紹了vue.js數(shù)據(jù)綁定的方法(單向、雙向和一次性綁定),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
vue指令只能輸入正數(shù)并且只能輸入一個小數(shù)點的方法
這篇文章主要介紹了vue指令只能輸入正數(shù)并且只能輸入一個小數(shù)點的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06

