本篇内容介绍了“怎么用vue递归实现自定义tree组件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
本文实例为大家分享了vue递归实现自定义tree组件的具体代码,供大家参考,具体内容如下
1. 在tree/index.vue中:
<template>
<div>
<ul>
<item :model='data'></item>
</ul>
</div>
</template>
<script>
import Item from './item'
export default {
components:{
Item
},
data(){
return{
data:{
title:"一级1",
children:[
{
title:"二级1-1",
children:[
{
title:"三级1-1-1",
children:[
{
title:"四级1-1-1-1",
children:[
{
title:"五级1-1-1-1-1"
}
]
}
]
}
]
},{
title:'二级1-2',
children:[
{
title:"三级1-2-1"
}
]
}
]
}
}
}
}
</script>
2. item.vue组件:
<template>
<li>
<div @click="toggle">
{{model.title}}
<span v-if="isFolder">[{{open?'-':'+'}}]</span>
</div>
<ul v-show="open" v-if="isFolder">
<item v-for="(child,index) in model.children" :model='child' :key='index'></item>
</ul>
</li>
</template>
<script>
export default {
name:'Item',
props:{
model:{
type:Object,
required:true
}
},
data(){
return{
open:false
}
},
computed:{
isFolder(){
return this.model.children && this.model.children.length>0
}
},
methods:{
toggle(){
if(this.isFolder) this.open =!this.open
}
}
}
</script>
3. 在任意组件中使用:
<template>
<div class="index">
<Tree></Tree>
</div>
</template>
<script>
import Tree from "@/components/tree"
components:{
Tree
}
</script>
“怎么用vue递归实现自定义tree组件”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。