Tree組件實現

遞歸組件Item建立

// Tree組件實現
// 遞歸組件item建立
<template>
  <li>
    <div @click="toggle">
    {{model.title}}
    <span v-if="isFolder">[{{open?'-':'+'}}]</span>
    </div>
    <ul v-show="open" v-if="isFolder"> 
      <item class="item" v-for="model in model.children" :model="model" :key="model.title"></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
    }
  },
  methods:{
    toggle(){
      if(this.isFolder){
        this.open = !this.open
      }
    }
  }
}
</script>

數據和使用

<template>
<div>
<ul>
<item class="item" :model="treeData"></item>
</ul>
</div>
</template>
<script>
import Item from "./Item";
export default {
name: "app",
data() {
return {
treeData: {
title: "Web全棧架構師",
children: [
{
title: "Java架構師"
},
{
title: "JS高級",
children: [
{
title: "ES6"
},
{
title: "動效"
}
]
},
{
title: "Web全棧",
children: [
{
title: "Vue訓練營",
expand: true,
children: [
{
title: "組件化"
},
{
title: "源碼"
},
{
title: "docker部署"
}
]
},
{
title: "React",
children: [
{
title: "JSX"
},
{
title: "虛擬DOM"
}
]
},
{
title: "Node"
}
]
}
]
}
};
},
components: { Item }
};
</script>
相關文章
相關標籤/搜索