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,内容如下:

 

{{ label }}

export default { props: [ 'label', 'nodes' ], name: 'tree-menu' }

登录后复制

如果你使用一个组件递归,必须先给 Vue.component 做一个全局的定义,或者,给它一个 name 属性。否则,任何子组件将无法进一步调用它,你会得到一个不确定的“undefined component error”的错误提示。

基本事件

与任何递归函数一样,你需要一个基本事件来结束递归,否则渲染将无限期地继续下去,最终会导致堆栈溢出。

在树菜单中,当我们到达一个没有子节点的节点的时候,我们希望停止递归。你能通过 v-if 做到这一功能,但我们选择使用 v-for 将隐式地为我们实现它;如果 nodes 数组没有任何进一步的定义 tree-menu 组件将被调用。template.vue文件如下:

 

...

登录后复制

使用用法

我们现在如何使用这个组件?首先,我们声明一个Vue实例,具有一个数据结构包括data属性和定义过的treemenu组件。app.js文件如下:

 import TreeMenu from './TreeMenu.vue' let tree = { ... } new Vue({ el: '#app', data: {  tree }, components: {  TreeMenu } })

登录后复制

请记住,我们的数据结构有一个根节点。我们在主模板开始递归调用 TreeMenu 组件,使用根 nodes 属性来props:

登录后复制

在视觉上识别子组件的“深度”是很好的,这样用户就可以从UI中获得数据结构的感觉。让我们缩进每一层的子节点来实现这个目标。

这是通过增加一个depth prop定义,通过 TreeMenu 来实现。我们将使用这个值动态地将内联样式与转换绑定在一起:将使用transform: translate的CSS规则为每个节点的标签,从而创建缩进。template.vue修改如下**:**

 

{{ label }}

export default { props: [ 'label', 'nodes', 'depth' ], name: 'tree-menu', computed: { indent() { return { transform: `translate(${this.depth * 50}px)` } } } }

登录后复制

depth 属性在主模板中从零开始。在上面的组件模板中,你可以看到每次传递到任何子节点时这个值都会递增。

登录后复制

注意:记得 v-bind depth值以确保它是一个JavaScript数字类型而不是字符串。

展开/收起

由于递归数据结构可能很大,所以显示它们的一个很好的UI技巧是隐藏除根节点以外的所有节点,以便用户可以根据需要展开或收起节点。

为此,我们将增加一个局部属性showChildren 。如果他的值为False,子节点将不会被渲染。此值应通过点击节点切换,所以我们需要使用一个单击事件的监听器方法 toggleChildren 来进行管理。template.vue文件修改如下**:**

 

{{ label }}

export default { props: [ 'label', 'nodes', 'depth' ], data() { return { showChildren: false } }, name: 'tree-menu', computed: { indent() { return { transform: `translate(${this.depth * 50}px)` } } }, methods: { toggleChildren() { this.showChildren = !this.showChildren; } } }

登录后复制

总结

这样,我们就有了一个工作树菜单。用来画龙点睛的一个方法是,你可以添加一个加号/减号图标,这样可以使UI的显示更加明显。我还增加了的很好的字体和计算性能在原来 showChildren 的基础上

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

JSONAPI在PHP中的使用方法

VueRouter的导航守卫应该怎么使用

立即学习“前端免费学习笔记(深入)”;

以上就是Vue.js怎样把递归组件构建为树形菜单的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2772731.html

(0)
上一篇 2025年3月8日 13:30:13
下一篇 2025年3月8日 13:30:20

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • anime.js做出动画复选框

    这次给大家带来anime.js做出动画复选框,anime.js做出动画复选框的注意事项有哪些,下面就是实战案例,一起来看一下。 anime.js anime.js是一个灵活的轻型JavaScript动画库。 它与CSS,个别变换,SVG,D…

    2025年3月8日 编程技术
    200
  • 利用阿里云+docker实现简单的node.js服务

    本篇文章给大家分享的内容是利用阿里云+docker实现简单的node.js服务,有着一定的参考价值,有需要的朋友可以参考一下 前提概要 实习的时候接触到docker,当时对其理解比较模糊。现在回学校做毕设,正好服务器这一块没人写,于是稍微复…

    2025年3月8日 编程技术
    200
  • JS随机排序数组

    这次给大家带来JS随机排序数组,JS随机排序数组的注意事项有哪些,下面就是实战案例,一起来看一下。 本文实例讲述了JS生成随机打乱数组的方法。分享给大家供大家参考,具体如下: 一、比较乱的排序方法 function fnLuanXu(num…

    编程技术 2025年3月8日
    200
  • JS实现计算器功能最简洁方法

    这次给大家带来JS实现计算器功能最简洁方法,JS实现计算器功能的注意事项有哪些,下面就是实战案例,一起来看一下。 具体代码: www.jb51.net JS计算器 // window.onload 获取元素getElementById wi…

    编程技术 2025年3月8日
    200
  • JS的一些隐式转换使用总结

    这次给大家带来JS的一些隐式转换使用总结,使用JS隐式转换的注意事项有哪些,下面就是实战案例,一起来看一下。 js中的不同的数据类型之间的比较转换规则如下: 1. 对象和布尔值比较 对象和布尔值进行比较时,对象先转换为字符串,然后再转换为数…

    编程技术 2025年3月8日
    200
  • JS如何实现Ajax的请求函数

    这次给大家带来JS如何实现Ajax的请求函数,JS实现Ajax请求函数的注意事项有哪些,下面就是实战案例,一起来看一下。 一般我们写网页的时候,如果用到 Ajax 请求服务器,都是使用 JQuery 等已经封装好的库来调用,比较简单。 但是…

    编程技术 2025年3月8日
    200
  • 原生JS如何对多个滚动条同步操作

    这次给大家带来原生JS如何对多个滚动条同步操作,原生JS对多个滚动条同步操作的注意事项有哪些,下面就是实战案例,一起来看一下。 在一些支持用 markdown 写文章的网站,后台写作页面,一般都是支持 markdown 即时预览的,也就是将…

    编程技术 2025年3月8日
    200
  • vue.js的计算属性介绍

    本篇文章给大家分享的内容是vue.js的计算属性介绍,有着一定的参考价值,有需要的朋友可以参考一下 computed方法 -声明了一个计算属性 reversedMessage 。提供的函数将用作属性 vm.reversedMessage 的…

    编程技术 2025年3月8日
    200
  • AngularJS如何实现动态加载Controller

    本篇文章给大家分享的内容是AngularJS如何实现动态加载Controller,有着一定的参考价值,有需要的朋友可以参考一下 我们把实现动态加载Controller方法封装到一个通用的模块里面,并命名这个模块为ngCommon。 (fun…

    编程技术 2025年3月8日
    200
  • 怎样开发最优的JS模块

    这次给大家带来怎样开发最优的JS模块,开发最优JS模块的注意事项有哪些,下面就是实战案例,一起来看一下。 不少人都曾经在 npm 上发布过自己开发的 JavaScript 模块,而在使用一些模块的过程中,我经常产生“这个模块很有用,但如果能…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论