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安全错误 数据库的锁怎样保障安全 dpi网络技术是什么意思 软件开发项目排期表模板 失落的方舟尝试服务器认证失败 数据库为什么要分层 剑侠世界3服务器更新时间 黑夜调色软件开发 主从数据库不同步 苹果把服务器建在贵州 混合加密网络安全吗 技术派数据库方案 盐田区新一代网络技术开发工艺 联想服务器bmc管理 特定网络技术服务价格合理 湖北智能软件开发 山西大型软件开发销售公司 数据库模糊匹配优化 监控报警服务器 icp备案网络安全 云综合安防管理平台服务器 服务器怎么匹配 亚马逊软件开发师 南关区品质网络技术咨询参考价格 计算机网络技术当老师工资多少 服务器防滑 类似宗益堂软件开发 如何建立服务器桌面 北京大型软件开发成本价 扬州网络安全使用方法 sql里的连接数据库文件 软件开发工具推荐