使用element-ui的el-menu导航选中后刷新页面保持当前选中状态
2019-07-19 13:58
2246 查看
具体代码如下所示:
<el-menu :default-active=‘$route.path‘ :router=‘true‘ :unique-opened=‘true‘ :default-openeds="defaultOpeneds" background-color="#bd1e22" text-color="#fff" active-text-color="#ffd04b"> //router当导航激活时允许以index作为路由进行页面的跳转,$route.path当前路由对象的路径,字符串,绝对路径 //unique-opened只允许有一个下拉菜单处于打开的状态 //使用default-active来实现当前菜单激活的选项 //default-openeds当前打开的 sub-menu 的 index 的数组 <el-menu-item index=‘/home‘>首页</el-menu-item> <el-submenu> <template slot="title"> <i class=‘‘></i><span>导航一</span> </template> <el-menu-item index=‘/first/page1‘> <template slot="title"> <i class=‘‘></i><span>选项一</span> </template> </el-menu-item> <el-menu-item index=‘/first/page2‘> <template slot="title"> <i class=‘‘></i><span>选项二</span> </template> </el-menu-item> </el-submenu> </el-menu >
mounted(){ let path = this.$route.path; this.navConfig = [ {index:'1',path:['/system/aa','/system/bb','/system/cc']}, ]; let thisNav = this.navConfig.find(item =>{ return item.path.includes(path); }); this.defaultOpeneds = [thisNav.index]; }
ps:下面看下vue Element-ui el-menu 左侧导航条
<template> <!--实现左侧导航条动态渲染(三级)--> <el-menu class="el-menu-vertical-demo" @open="handleOpen" @close="handleClose" :collapse="isCollapse" router unique-opened background-color="#545c64" text-color="#fff" active-text-color="#ffd04b"> <el-menu-item index="/home/main"> <i class="el-icon-document"></i> <span slot="title">首页</span> </el-menu-item> <el-submenu v-for="(item,index) in content" :key="item.id" :data="item" v-if="item.children.length>0&&item.level==1" :index="item.linkname"> <template slot="title"> <i class="el-icon-location"></i> <span slot="title">{{item.linkname}}</span> </template> <el-submenu v-for="(child,seq) in item.children" :data="child" v-if="item.id==child.parentid&&child.children.length>0&&child.level==2" :key="child.id" :index="child.linkname"> <span slot="title">{{child.linkname}}</span> <el-menu-item v-for="three in child.children" :data="three" v-if="child.id==three.parentid&&child.children.length!=0&&three.level==3" :key="three.id" :index="three.link"> <span slot="title">{{three.linkname}}</span> </el-menu-item> </el-submenu> <!--2无子级显示--> <el-menu-item v-for="(child,seq) in item.children" :data="child" v-if="item.id==child.parentid&&child.children.length==0&&child.level==2" :key="child.id" :index="child.link"> <span slot="title">{{child.linkname}}</span> </el-menu-item> </el-submenu> <!--1无子级显示且不支持点击事件--> <el-menu-item v-for="(item,index) in content" :key="item.id" :data="item" v-if="item.children.length==0&&item.level==1" :index="item.linkname" :disabled="item.children.length==0 ? true : false "> <i class="el-icon-setting"></i> <span slot="title">{{item.linkname}}</span> </el-menu-item> </el-menu> </div> </template> <script> import axios from "axios"; import $ from 'jquery'; export default { data() { return { content: [], isCollapse: false, defaultProps: { children: 'children', label: 'linkname' } }; }, mounted(){ var _self = this; axios.get('https://5b90a18b3ef10a001445d08e.mockapi.io/api/v1/resources') .then(function (response) { _self.content = returnZhData(response.data); }) .catch(function (error) { console.log(error); }); }, methods: { handleOpen(key, keyPath) { console.log(key, keyPath); }, handleClose(key, keyPath) { console.log(key, keyPath); }, handleNodeClick(content) { console.log(content); } } } function returnZhData(data){ var arrone=[]; $.each(data, function(index,one) { if(one['level'] == 1){ arrone.push(one); var arrtwo=[]; $.each(data, function(index,two) { if(two['level'] == 2 && two['parentid']==one['id']){ arrtwo.push(two); var arrthree=[]; $.each(data, function(index,three) { if(three['level'] == 3 && three['parentid']==two['id']){ arrthree.push(three); } }); two.children=arrthree; } }); one.children = arrtwo; } }); return arrone; } </script> <style> .el-menu-vertical-demo:not(.el-menu--collapse) { width: auto; min-height: 400px; } </style>
总结
以上所述是小编给大家介绍的使用element-ui的el-menu导航选中后刷新页面保持当前选中,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
您可能感兴趣的文章:
相关文章推荐
- 解决element-ui中el-menu组件作为vue-router模式在刷新页面后default-active属性与当前路由页面不一致问题的方法
- 解决element-ui框架下导航菜单el-menu 刷新后菜单高亮问题
- js实现刷新页面后select标签保持选中状态
- 导航跳转后保持选中状态 jquery高亮当前选中菜单
- 使用react-router-dom优雅的实现页面(路由)跳转, 而且保持当前页面状态
- vue.js+element-ui,页面中使用row-class-name属性达到表格中状态、颜色的区分
- 用vue+Element-ui写一个后台管理界面,点击头部导航对应显示下方左侧导航菜单,点击左侧菜单对应显示右边内容,点击右边内容的按钮出现一个新页面依旧能够选中左侧相应菜单,求解决???!!!!
- JS实现对gridview中的checkbox的选中个数记录,并在页面刷新时保持checkbox的状态 .
- vue Element动态设置el-menu导航当前选中项
- elementui select组件选中后无法自动刷新更新值渲染到页面中
- vue+element ui 使用$refs获取el-dialog 下的 el-table 组件 ,以及使用table多选,默认选中
- 鼠标移到导航当前位置的LI变色处于选中状态
- vue 使用element-ui的el-input监听不了回车事件
- ajax 无刷新状态下,使用ModalPopupExtender跳出的子页面选择内容
- vue使用element-ui的el-input监听不了回车事件的解决方法
- 鼠标移到导航当前位置的LI变色处于选中状态
- android selector 背景选择器的使用, button (未点击,点击,选中保持状态)效果实现
- ShopEx 手动使用分类做导航时,获取当前导航的焦点状态
- 如何使用jquery刷新当前页面
- 使用ElementUI + el-date-picker开发, 报错getTime is not a function