当前位置: 首页 > article >正文

vue之递归组件

递归组件是指在其自身模板中引用自己的 Vue 组件。这在需要处理嵌套数据结构(如树形数据、嵌套评论等)时非常有用

示例:树形结构

假设我们有一个嵌套的树形数据结构,并希望使用递归组件来渲染它。

数据结构
const treeData = {
  name: "Root",
  children: [
    {
      name: "Child 1",
      children: [
        { name: "Grandchild 1-1", children: [] },
        { name: "Grandchild 1-2", children: [] }
      ]
    },
    {
      name: "Child 2",
      children: []
    }
  ]
};
TreeNode 组件 (TreeNode.vue)
<template>
  <div class="tree-node">
    <span>{{ node.name }}</span>
    <ul v-if="node.children && node.children.length">
      <li v-for="(child, index) in node.children" :key="index">
        <!-- 递归调用自身 -->
        <TreeNode :node="child" />
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  name: 'TreeNode',
  props: {
    node: {
      type: Object,
      required: true
    }
  },
  components: {
    TreeNode: () => import('./TreeNode.vue') // 递归注册自身
  }
};
</script>

<style scoped>
.tree-node {
  margin-left: 20px;
}
</style>
根组件(例如 App.vue
<template>
  <div id="app">
    <TreeNode :node="treeData" />
  </div>
</template>

<script>
import TreeNode from './components/TreeNode.vue';

export default {
  name: 'App',
  components: {
    TreeNode
  },
  data(){
	  return {
		  treeData:{
		     name: "Root",
		      children: [
		        {
		          name: "Child 1",
		          children: [
		            { name: "Grandchild 1-1", children: [] },
		            { name: "Grandchild 1-2", children: [] }
		          ]
		        },
		        {
		          name: "Child 2",
		          children: []
		        }
		      ]
		    }
	  }
  }
};
</script>

解释

  1. TreeNode 组件:

    • name 属性用于指定组件的名称。
    • props 定义了 node 属性,这是一个对象类型且必需的属性,用于传递当前节点的数据。
    • components 中递归注册自身,使得组件内部可以调用自己。
    • 在模板部分,通过 <TreeNode :node="child" /> 来递归调用自身,并传递子节点的数据。
  2. 根组件 (App.vue):

    • 导入 TreeNode 组件,并在模板中使用它。
    • 使用 setup 函数定义 treeData 并将其传递给 TreeNode 组件。

递归组件的注意事项

  • 终止条件:确保在递归过程中有一个明确的终止条件,否则会导致无限循环。例如,在上面的示例中,我们通过检查 children 数组是否为空来决定是否进行递归调用。
  • 性能考虑:对于大型数据集,深度嵌套的递归可能会影响性能。你可以考虑优化策略,如懒加载子节点或限制递归深度。

http://www.kler.cn/a/281688.html

相关文章:

  • 基于YOLOv8深度学习的无人机航拍小目标检测系统(PyQt5界面+数据集+训练代码)
  • 青少年编程与数学 02-003 Go语言网络编程 21课题、Go语言WebSocket编程
  • IDEA2023 创建SpringBoot项目(一)
  • 学习threejs,通过SkinnedMesh来创建骨骼和蒙皮动画
  • NIST 发布后量子密码学转型战略草案
  • 面试题: Spring中的事务是如何实现的?
  • 单例模式在实现webserver这个项目中起到了什么作用
  • 回调函数基本实现
  • 什么是跨域问题?出现的原因和解决方法是什么?
  • 自动化常用元素定位
  • pymysql 与 MySQL数据库交互
  • 程序员的自我修炼:如何拒绝快餐式学习,深耕技能20240829
  • windows消息机制之HMIsMarkDestroy宏定义的理解
  • c语言——数组
  • 基于my Batis优化图书管理系统(一)
  • FastAdmin 和 Dcat Admin从使用场景、适合人群、使用成本、资源完善程度、bug 解决、安全性全方位解析
  • go 系列实现websocket
  • 【数据结构-前缀异或和】力扣1371. 每个元音包含偶数次的最长子字符串
  • C#过 SemaphoreSlim 实现高效的数据库并发控制和资源管理(多线程)
  • 鸿蒙HSP,HAP,HAR
  • 基于matlab的深度学习案例及基础知识专栏前言
  • 基于imx6ull平台opencv的图像采集和显示屏LCD显示功能(不带Qt界面)
  • Android JNI开发:System.loadLibrary加载机制
  • Kubernetes:解决命名空间无法正常删除问题 —— 清空 Finalizers 字段的方法步骤
  • XDMA原理
  • beforeEach中addRoutes后使用next()无法访问,路由未生效,刷新页面白屏,使用next({ ...to, replace: true })