Element UI导航菜单刷新就复原问题解决方法~

1、首先要知道为什么一刷新就复原了,是因为default-active属性设置的是默认值,是一个死值,一旦刷新就会复原,造成高亮不能保持,那么怎么解决呢?

2、很简单,无需像一些博主一样绑定path。思路:既然一刷新就复原了,那么我们在切换的时候就将值存储在本地存储或vuex中呗。

方法一:本地存储

javascript 复制代码
<el-menu
  :default-active="activeIndex2" class="el-menu-demo" mode="horizontal"
  @select="handleSelect" background-color="#545c64" text-color="#fff"
  active-text-color="#ffd04b"
>
    <el-menu-item :index="String(index)" v-for="(item,index) in list" :key="item.id">{{ item.name }}</el-menu-item>
    <el-submenu index="4">
      <template slot="title">我的工作台</template>
      <el-menu-item index="4-1">设置</el-menu-item>
      <el-menu-item index="4-2" >退出</el-menu-item>
    </el-submenu>
</el-menu>

<script>
export default {
  name: "showTop",
  data() {
    return {
      list: [{name:"首页",id:0},{name:"商品",id:1},{name:"订单",id:2},{name:"会员",id:3},{name:"设置",id:4},{name:"管理员",id:5}],
      activeIndex2: null
    };
  },
  mounted(){
    if(localStorage.getItem('activeIndex2')){
      this.activeIndex2 =localStorage.getItem('activeIndex2')
    }else{
      this.activeIndex2 =String(this.list[0].id)
    }
  },
  methods: {
    // 顶部导航栏点击事件
    handleSelect(key, keyPath) {
        console.log(key,keyPath);
        // 解决element ui组件库中顶部导航栏刷新复原问题,也可存储在vuex中
        localStorage.setItem('activeIndex2',String(this.list[key].id))
        // 判断是否是退出按钮
        if(key=='4-2'){
          // 清空本地缓存的token
          localStorage.removeItem('token')
          // 跳转至登录页
            this.$router.push({name:'login'})
        }
      }
  },
};
</script>

方法二:vuex+本地存储

javascript 复制代码
<el-menu
  :default-active="activeIndex2" class="el-menu-demo" mode="horizontal"
  @select="handleSelect" background-color="#545c64" text-color="#fff"
  active-text-color="#ffd04b"
>
    <el-menu-item :index="String(index)" v-for="(item,index) in list" :key="item.id">{{ item.name }}</el-menu-item>
    <el-submenu index="4">
      <template slot="title">我的工作台</template>
      <el-menu-item index="4-1">设置</el-menu-item>
      <el-menu-item index="4-2" >退出</el-menu-item>
    </el-submenu>
</el-menu>

<script>
import { mapMutations} from 'vuex';
export default {
  name: "showTop",
  data() {
    return {
      list: [{name:"首页",id:0},{name:"商品",id:1},{name:"订单",id:2},{name:"会员",id:3},{name:"设置",id:4},{name:"管理员",id:5}],
      activeIndex2: null
    };
  },
  mounted(){
    if(localStorage.getItem('activeIndex2')){
      this.activeIndex2 =localStorage.getItem('activeIndex2')
    }else{
      this.activeIndex2 =String(this.list[0].id)
    }
  },
  methods: {
    ...mapMutations(['setActiveIndex2']),
    // 顶部导航栏点击事件
    handleSelect(key, keyPath) {
        console.log(key,keyPath);
        // 存储到vuex中,但是要记住还需要在vuex中存储到本地存储中
        this.setActiveIndex2(String(this.list[key].id))
        // 判断是否是退出按钮
        if(key=='4-2'){
          // 清空本地缓存的token
          localStorage.removeItem('token')
          // 跳转至登录页
            this.$router.push({name:'login'})
        }
      }
  },
};
</script>
javascript 复制代码
//store中的index.js
import Vue from "vue"
import Vuex from "vuex"
Vue.use(Vuex)

export default new Vuex.Store({
    state:{
        activeIndex:'',
    },
    mutations:{
        setActiveIndex2(state,e){
            state.activeIndex = e
            window.localStorage.setItem('activeIndex2',e)
        }
    },
})
javascript 复制代码
import Vue from 'vue'
import App from './App.vue'
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import router from '../router';
import store from '../store';
Vue.use(ElementUI);

Vue.config.productionTip = false

new Vue({
  router,
  store,
  render: h => h(App),
}).$mount('#app')

效果图:

相关推荐
无心使然云中漫步1 小时前
GIS OGC之WMTS地图服务,通过Capabilities XML描述文档,获取matrixIds,origin,计算resolutions
前端·javascript
Bug缔造者1 小时前
Element-ui el-table 全局表格排序
前端·javascript·vue.js
xnian_2 小时前
解决ruoyi-vue-pro-master框架引入报错,启动报错问题
前端·javascript·vue.js
罗政2 小时前
[附源码]超简洁个人博客网站搭建+SpringBoot+Vue前后端分离
vue.js·spring boot·后端
麒麟而非淇淋2 小时前
AJAX 入门 day1
前端·javascript·ajax
2401_858120533 小时前
深入理解MATLAB中的事件处理机制
前端·javascript·matlab
阿树梢3 小时前
【Vue】VueRouter路由
前端·javascript·vue.js
随笔写4 小时前
vue使用关于speak-tss插件的详细介绍
前端·javascript·vue.js
快乐牌刀片884 小时前
web - JavaScript
开发语言·前端·javascript
秋雨凉人心5 小时前
call,apply,bind在实际工作中可以使用的场景
javascript