• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

vuejs使用递归组件实现树形目录的方法

vue 搞代码 4年前 (2022-01-08) 46次浏览 已收录 0个评论

本篇文章主要介绍了vuejs使用递归组件实现树形目录的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

上篇文章我提到了通讯录的开发,里面的目录使用了vue的递归组件实现的树形目录,这篇文章就来讲讲如何实现树形目录吧!

首先实现效果如下,觉得菜单还是比较nice的是吧:

这边数据调用的是数据库的数据的,需要数据库进行数据的构造,这里涉及到java的构造多叉树的知识,后续我会另外写一篇文章详细讲解,这里讲下前端。

数据可以先构造json使用,这里用到的格式大概如下,以childList来嵌套子菜单:

 { id:YH, name:银行, pid:0, childList:[{ id:YH******, name:国家开发银行, pid:YH, childList:[{ id:YH*****3, name:国家开发银行香港分行, pid:YH******, childList:[] }, { id=YH*****1, name=国家开发银行广东省分行, pid=YH******, childList=[] }, { id=YH*****2, name=国家开发银行深圳分行, pid=YH******, childList=[] } ]} } 

按照思路,我们是要ul里面套li,li里面套ul,这样无限套用,所以在子组件里面这么写:

 <li> <div> <i class="mui-icon iconfont"></i><!--isFolder判断是否存在子级改变图标--><i class="mui-icon iconfont icon-wenjian" style="color: #00ccff"></i><!--这里用到的方法是给父组件传值,具体可看上一篇文章--><span> {{model.name}} </span></div><ul> </ul></li>

在官方文档里面强调了name属性,所以我们在开始还要定义name,这边的name用到的是上面的tree-menu:

 export default { name: 'treeMenu', props: ['model'], components: {} }

按照vue的思想,不操作Dom树,我们定义两个变量,一个显示隐藏子菜单(open),一个存不存子菜单修改图标(isFolder)。

 data() { return { open: false, isFolder: true, } },

我是参照一篇文章编写的,在这一步说的是“利用vue计算属性动态改变isFolder的值,修改图标,判断存在不子级和子级长度”

 computed: { isFolder() { return this.model.childTreeNode && this.model.childTreeNode.length } }  

这里就出现了个问题,会一直不停地报错:

找了很久的问题,结果我是这样解决的,去掉computed的计算属性,将其放到created里面:

 created(){ //将isFolder<mark>本文来源gaodaimacom搞#代%码@网-</mark>放在这里判断可以识别出最底层菜单,然后改变图标,放在computed的话会一直报错并识别不出最底层菜单改变样式 this.isFolder = this.model.childList && this.model.childList.length; }

显示/隐藏事件

 methods: { toggle: function() { if(this.isFolder){ this.open = !this.open; } }, }

到这里就构造好树形目录的组件了,只要在相应的父组件里面调用就行了,完整代码如下:

父组件中引用

 <ul class="tree_container"> </ul>

子组件:

  <li> <div> <i class="mui-icon iconfont"></i><!--isFolder判断是否存在子级改变图标--><i class="mui-icon iconfont icon-wenjian" style="color: #00ccff"></i><span> {{model.name}} </span></div><ul> </ul></li> ul { list-style: none; padding-left: 20px; } ul li{ list-style: none; } a{ color: #404040; //text-decoration: underline; } i.icon { display: inline-block; width: 15px; height: 15px; background-repeat: no-repeat; vertical-align: middle; } i{ opacity: 0.8; color: #f0ad4e; } .tree-menu li { line-height: 1.5; } 

子组件可以直接使用,样式也一起贴出来了,但是在父组件中也有点样式,就留给你们自己操作了,这个完整的代码里面还包括了上篇文章提到的组件传值的部分。

我的icon用的是阿里的iconfont,大家也可以百度搜一下

以上就是vuejs使用递归组件实现树形目录的方法的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:vuejs使用递归组件实现树形目录的方法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址