Vue 递归插件

 app.vue 递归List里面的label数据

1.传入list数据到插件

<!-- App.vue -->
<template>
  <div>
    <recursionVue :list="list"></recursionVue>
  </div>
</template>

<script>
import recursionVue from "./view/recursion.vue"
export default {
  components: {
    recursionVue,
  },
  data() {
    return {
      list: [
        {
          label: "一级",
          children: [
            {
              label: "二级1-1",
              children: [
                {
                  label: "三级1-1",
                },
              ],
            },
          ],
        },
      ],
    }
  },
}
</script>

<style></style>

recursionVue插件

2.判断list的每一项有没有children

有children调用插件(自己)

没有children退出循环

<template>
  <div>
    <div v-for="(item, index) in list" :key="index">
      {{ item.label }}

      <!-- 检测item里面有没有children项 -->
      <div v-if="Object.keys(item).includes('children')">
        <!-- 如果有children项,继续调用recursionVue插件 -->
        <recursionVue :list="item.children"></recursionVue>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  name: "recursionVue",
  props: ["list"],
}
</script>

<style></style>

递归,找到相同计算的共同点,作为传入的数据或判断

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值