html可折叠tree,用 Vue.js 递归组件实现可折叠的树形菜单(demo)_奔赴_前端开发者

本文介绍了如何使用Vue.js构建一个可折叠的树形菜单。通过递归组件实现,数据结构包含标签和子节点。文章详细讲解了组件的创建,包括基本事件处理、缩进样式以及展开/收起功能的实现。最后,提供了CodePen上的完整示例链接供读者参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ce98a3dee4012bc85c8ee169e2bc6fd4.png

递归组件常用于在blog上显示注释、嵌套的菜单,或者基本上是父和子相同的类型,尽管具体内容不同。例如:

60ba2c620b166852b3c3d685aeed4be9.png

现在给您演示一下如何有效地使用递归组件,我将通过建立一个可扩展/收缩的树形菜单的来一步步进行。

数据结构

一个树状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.

{{ label }}

v-for="

如果你使用一个组件递归,必须先给

基本事件

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

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

...

0412d0086863e677b0716b474f108b03.png

下面是它目前的样子:

正确的姿势

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

48195e4278393e7652b61de0a64544ee.png

这是通过增加一个 depth prop定义,通过 TreeMenu 来实现。我们将使用这个值动态地将内联样式与转换绑定在一起:将使用 transform: translate 的

{{ label }}

v-for="

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

:label="tree.label"

:nodes="tree.nodes"

:depth="0"

>

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

展开/收起

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

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

{{ label }}

v-if="showChildren"

v-for="node in nodes"

:nodes="node.nodes"

:label="node.label"

:depth="depth + 1"

>

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 的基础上。

去CodePen( https://codepen.io/anthonygore/pen/PJKNqa)可以看看我是如何实现它的。

b6601f30ac458a9c1adc4f31689ad933.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值