vue+iview的菜单与页签的联动

最近在使用vue+iview开发一个后台管理类的系统,希望做一个点击左侧菜单右侧的页签与内容都能相对应的改变。但搞了好久的路由也没有实现这个功能。刚开始使用vue+iview不知道iview-admin可以直接拿来使用,布局之类的开箱即用,可是自己的demo已经写了好久不忍心放弃。

一、使用iview的menu和tab做布局,将这两个组件放到主页面

由于menu与tab的数据相同且样式需要进行关联,因此可以使用vuex进行状态管理,state中写入需要管理的数据和状态变量,在mutations中设置操作的动作,actions中监听一些行为(我的菜单没有展开收缩部分,因此并没有使用到actions)

vue+iview的菜单与页签的联动_第1张图片

vue+iview的菜单与页签的联动_第2张图片

二、做好布局之后要对菜单增加点击事件:on-select,首先在mutations中注册tab的改变事件,当左侧菜单点击的时候查看tab中是否已经有这个页签并设置isExist=false,如果存在,isExist修改为true,没有的话给tab对应遍历的数组增加菜单相对索引的数据。

mutationsType中

vue+iview的菜单与页签的联动_第3张图片

mutations中:

vue+iview的菜单与页签的联动_第4张图片

menu组件中的事件为:

vue+iview的菜单与页签的联动_第5张图片

在tab组件中首先设置页面默认路由:

vue+iview的菜单与页签的联动_第6张图片

再将事件加入进去:

vue+iview的菜单与页签的联动_第7张图片


你可能感兴趣的:(vue学习,JavaScript学习)