html 左侧 树形菜单,vue左侧菜单,树形图递归实现代码

学习vue有一段时间了,最近使用vue做了一套后台管理系统,左侧菜单需求是这样的,可以多层,数据由后台传递。也因为自己对官方文档的不熟悉使得自己踩了不少坑,今天写出来和大家一起分享。

效果图如下所示:

fe791a79ae04e943d8d60eab2e1a58ec.png

先说说遇到的坑,由于是子父组件,当时传递使用的是子父组件的传递,但是这时候只能获取到第一层的数据,第二层往后获取不到数据,踩了一下午坑以后才知道,子组件使用了递归组件,这时候他已经不能往父组件传递了,子传父,只能逐层传递这时候已经隔层了,所以我使用了非子父组件传递,两个页面都引入bus.js,这里不懂的请百度。

bus.js

import Vue from 'vue'

export default new Vue

父组件内容

模拟后台数据

theModel:[{

'id': '1',

'menuName': '导航1',

'menuCode': '10',

'menuUrl':'',

'childMenus': [

{

'menuName': '用户管理',

'menuCode': '11',

'menuUrl':'/home',

'menuPath':'',

'childMenus':[{

'menuName': '11111',

'menuCode': '12',

'menuUrl':'/systemjuri',

'menuPath':'',

'childMenus': []

}]

},

{

'menuName': '角色管理',

'menuCode': '12',

'menuUrl':'/systemjuri',

'menuPath':'',

'childMenus': []

},

{

'menuName': '菜单管理',

'menuUrl':'/systemmenu',

'menuCode': '13',

'menuPath':'http://10.63.195.214:8080/menuManage/html/index_3.html',

'childMenus':[]

}]

},{

'id': '1',

'menuName': '导航2',

'menuCode': '10',

'childMenus':[]

}],

父组件引入子组件

import myTree from './treeMenu.vue'

export default {

components: {

myTree

},

}

父组件接受子组件传递的数据

bus.$on("childEvent", function(transmit) {})

下面是子组件内容,子组件名称treeMenu,name: 'treeMenu',

{{ model.menuName }}

import bus from "./../../../static/js/bus";

export default {

name: 'treeMenu',

props: ['model'],

data() {

return {

open: false,

}

},

computed: {

isFolder() {

return this.model.childMenus && this.model.childMenus.length

}

},

methods: {

toggle(msg,menuUrl,menuPath) {

if (this.isFolder) {

this.open = !this.open

}

var json = { msg: msg, menuUrl: menuUrl,menuPath:menuPath };

bus.$emit("childEvent", json)

},

}

}

ul {

list-style: none;

}

i.icon {

display: inline-block;

width: 15px;

height: 15px;

background-repeat: no-repeat;

vertical-align: middle;

float: right;

margin-top: 17px;

margin-right:30px;

}

.icon.folder {

background-image: url('./homeimg/left_1.png');

}

.icon.folder-open {

background-image: url('./homeimg/dowm_1.png');

}

.icon.file-text {

}

ul li ul li .icon.folder {

background-image: url('./homeimg/left_2.png');

}

ul li ul li .icon.folder-open {

background-image: url('./homeimg/down_2.png');

}

.tree-menu li {

line-height: 50px;

}

span{

display: block;

width: 100%;

height: 100%;

}

ul{

padding-left:10px;

}

ul li span{

text-indent: 10px;

}

ul li ul{

background:#ebf1f8;

color:#1457a7;

}

li:hover{

cursor:pointer;

}

由于用了递归组件所以name需要和对应起来

总结

以上所述是小编给大家介绍的vue左侧菜单,树形图递归实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值