Vue.js中如何利用递归组件构建树形菜单
本文小编为大家详细介绍"Vue.js中如何利用递归组件构建树形菜单",内容详细,步骤清晰,细节处理妥当,希望这篇"Vue.js中如何利用递归组件构建树形菜单"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
在Vue.js中一个递归组件调用的是其本身,如:
Vue.component('recursive-component', { template: ` });递归组件常用于在blog上显示注释、嵌套的菜单,或者基本上是父和子相同的类型,尽管具体内容不同。例如:
现在给您演示一下如何有效地使用递归组件,我将通过建立一个可扩展/收缩的树形菜单的来一步步进行。
数据结构
一个树状UI的递归组件将是一些递归数据结构的可视化表达。在本教程中,我们将使用树状结构,其中每个节点都是一个对象:
一个 label 属性。
如果它有子节点,一个 nodes 属性,则它是一个或多个节点的数组属性。
与所有树结构一样,它必须有一个根节点,但可以无限深。
let tree = { label: 'root', nodes: [ { label: 'item1', nodes: [ { label: 'item1.1' }, { label: 'item1.2', nodes: [ { label: 'item1.2.1' } ] } ] }, { label: 'item2' } ] }递归组件
让我们做一个递归组件来显示我们的称为 TreeMenu 的数据结构。它只显示当前节点的标签,并调用自己来显示任何子节点。文件名:TreeMenu.vue,内容如下:
如果你使用一个组件递归,必须先给 Vue.component 做一个全局的定义,或者,给它一个 name 属性。否则,任何子组件将无法进一步调用它,你会得到一个不确定的"undefined component error"的错误提示。
基本事件
与任何递归函数一样,你需要一个基本事件来结束递归,否则渲染将无限期地继续下去,最终会导致堆栈溢出。
在树菜单中,当我们到达一个没有子节点的节点的时候,我们希望停止递归。你能通过 v-if 做到这一功能,但我们选择使用 v-for 将隐式地为我们实现它;如果 nodes 数组没有任何进一步的定义 tree-menu 组件将被调用。template.vue文件如下:
组件 递归 节点 结构 属性 数据 数据结构 菜单 树形 内容 文件 事件 文章 模板 数组 标签 用户 类型 进一 妥当 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 网络安全论文小结 织梦数据库文件在哪 显示屏转换器链接连接不到服务器 互联网农业科技公司 vb访问mysql数据库 设备接入网络安全准入控制 上海计算机软件开发总公司 浪潮 GPU 服务器 宁波畅享软件软件开发工程师面试 体育人群数据库如何变现 南通高科技软件开发创新服务 陕西电商软件开发报价 宁夏网络安全宣传信息 网络安全创业项目计划书 阿里云ecs服务器试用体验 黑客攻击fbi服务器电影 黑客军团用到的网络技术 软件开发用例数 服务器满了新号进不去怎么办 公开接口返回xml数据库 腾讯云服务器远程登录 上海网络技术学院录取分数线 数据库自动删除备份文件夹 ca证书服务器搭建 吉林服务器机柜供应商 内控 数据库建立的重要性 讲网络安全的名句 软件开发流程概要设计 黑客攻击fbi服务器电影 实施计算机信息网络安全保护