日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

VUE 無限層級樹形數據結構顯示的實現

瀏覽:210日期:2022-09-28 13:57:24
目錄組件遞歸調用使用render方法

在做項目中,會遇到一些樹形的數據結構,常用在左側菜單導航,或者評論引用等地方,這種數據結構有個特點是不知道它會嵌套多少層,所以用template去展示這樣的數據時就有點棘手,這篇文章梳理兩種展示這種數據結構的方法。

文章中用到的數據是下面這個:

mainData: { value: 'root', children:[{ value: '層級1-1', children:[{ value: '層級2-1', children:[{ value: '層級3-1', children:[] }] },{ value: '層級2-2', children:[] }] },{ value: '層級1-2', children:[] }]}

也就是下面這個樣子。

VUE 無限層級樹形數據結構顯示的實現

組件遞歸調用

第一種是組件遞歸調用自己的方式,創建一個組件,該組件在引用自己去展示children的數據,子組件如下:

<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>

然后創建父組件,父組件使用子組件,并將數據傳入子組件。

<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>

關于遞歸組件的內容,在官方文檔里是有提到的-->遞歸組件

使用render方法

除了使用組件的方式,也可以使用vue的render方法,去利用JavaScript 的完全編程的能力,實現遞歸處理樹形數據,從而展示出無限層級樹。如下:

<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方法用遞歸的方式,深度優先遍歷樹狀數據,生成vnode,然后渲染出了頁面。

到此這篇關于VUE 無限層級樹形數據結構顯示的實現的文章就介紹到這了,更多相關VUE 無限層級樹形結構內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩一区二区国产| 国产精品久久久久久久免费观看| 黑森林国产精品av| 久久一区视频| 91一区二区| 超碰99在线| 成人看片网站| 久久狠狠婷婷| 免费国产自久久久久三四区久久| 麻豆精品蜜桃| 正在播放日韩精品| 精品免费av在线| 欧美亚洲国产精品久久| 日韩中文字幕高清在线观看| 精品久久精品| 国产h片在线观看| 久久精品影视| 合欧美一区二区三区| 男人操女人的视频在线观看欧美| 一二三区精品| 国产欧美日韩在线观看视频| 欧美激情福利| 大香伊人久久精品一区二区| 国产盗摄——sm在线视频| 日产精品一区二区| 欧美亚洲在线日韩| 久久亚洲二区| 美腿丝袜亚洲三区| 精品国产乱码| 国内激情久久| 亚洲三级毛片| 国产一精品一av一免费爽爽| 国产精品亚洲产品| 成人综合一区| 欧美成人国产| 亚洲三级毛片| 老司机免费视频一区二区| 日韩大片在线观看| 欧美日韩高清| 日本aⅴ免费视频一区二区三区| 国产欧美亚洲精品a| 成人午夜毛片| 国产免费成人| 日韩精品五月天| 久久一区视频| 久久中文字幕av| 视频一区日韩| 国产a亚洲精品| 中文国产一区| 国产精品亚洲欧美日韩一区在线| 日韩理论片av| 亚洲一区二区三区四区五区午夜 | 97人人精品| 亚洲在线国产日韩欧美| 欧美在线91| 少妇精品导航| 天堂久久av| 综合国产精品| 岛国av免费在线观看| 亚洲一区日韩| 精品亚洲二区| 中日韩男男gay无套| 国产精品一区二区美女视频免费看| 欧美精品资源| 日韩av成人高清| 亚洲播播91| 亚洲精品韩国| av综合电影网站| 日本不卡中文字幕| 999国产精品视频| 国产精品视频一区二区三区 | 国产美女撒尿一区二区| 久久久久久免费视频| 日本欧美在线| 久久国产电影| 国产精品伊人| 在线观看免费一区二区| 欧美国产精品| 蜜臀av国产精品久久久久| 91麻豆国产自产在线观看亚洲| 亚洲资源网站| 美日韩精品视频| 在线亚洲人成| 国产精品毛片视频| 免费在线观看成人| 久久久久蜜桃| 精品网站999| 日韩黄色av| 国产综合精品一区| 在线视频亚洲| 日韩高清成人| 国产精品高潮呻吟久久久久| 日韩亚洲国产欧美| 日韩在线第七页| 久久香蕉网站| 国产欧美日本| 日韩福利在线观看| 免费精品视频在线| 狠狠色狠狠色综合日日tαg| 欧美日韩免费看片| 欧美经典一区| 日本a级不卡| 亚洲免费毛片| 亚洲综合日本| 五月天激情综合网| 999视频精品| 国产精品第十页| 亚洲精品日本| 亚洲欧洲一区| 亚洲精品网址| 国产综合精品一区| 久久婷婷亚洲| 深夜视频一区二区| 中文在线а√在线8| 国产欧美88| 亚洲精品九九| 亚洲欧洲美洲国产香蕉| 男女精品网站| 久久xxxx| 美女网站久久| 久久亚洲风情| 国产精品日本欧美一区二区三区| 亚洲韩日在线| 欧美日韩国产高清| 亚洲精品网址| 日韩天堂av| 国产亚洲网站| 午夜在线观看免费一区| 丝袜美腿亚洲色图| 老牛影视一区二区三区| 丝袜亚洲精品中文字幕一区| 国产精品日韩久久久| 在线亚洲激情| 欧美专区在线| 亚洲精品无播放器在线播放| 亚洲乱亚洲高清| 免费看欧美美女黄的网站| 久久午夜视频| 日本午夜免费一区二区| 国产精品资源| 精品久久影院| 日韩网站中文字幕| 一区视频在线| 亚洲日本在线观看视频| 91成人在线| 精品久久免费| 99久久久久国产精品| 欧美日韩国产综合网| 免费日韩av片| 97久久精品| 麻豆精品一区二区综合av| 里番精品3d一二三区| 精品国产一区二区三区性色av| 在线人成日本视频| 午夜国产一区二区| 蜜臀久久99精品久久久久久9| 日本不卡一区二区三区| 国产精品毛片视频| 天堂√8在线中文| 尹人成人综合网| 日韩福利视频网| 国产一区二区亚洲| 欧美/亚洲一区| 涩涩涩久久久成人精品| 久久不见久久见免费视频7| 四虎国产精品免费观看| 欧美~级网站不卡| 午夜亚洲福利在线老司机| 日本va欧美va欧美va精品| 国产成人77亚洲精品www| 不卡一区综合视频| 日本不卡一区二区| 国产精品久久久久久久久妇女| 图片区亚洲欧美小说区| 日本电影久久久| 日韩啪啪电影网| 久久亚洲影院| 国产激情久久| 免费黄色成人| 91九色综合| 99久久久久国产精品| 日韩精品亚洲专区| 精品72久久久久中文字幕| 精品一区欧美| 欧美亚洲tv| 久久精品国产www456c0m| 日韩精选在线| 成人欧美一区二区三区的电影| 亚洲自啪免费| 精品伊人久久| 丝袜国产日韩另类美女| 日韩电影二区| 97久久中文字幕| 激情久久久久久| 国产精品久久久久77777丨 | 欧美va天堂| 国产精品xvideos88| 99久久久国产精品美女| 欧美日本久久| 蜜臀精品一区二区三区在线观看 |