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')

效果图:

相关推荐
daols881 小时前
vue vxe-table 自适应列宽,根据内容自适应宽度的2种使用方式
vue.js·vxe-table
OEC小胖胖3 小时前
告别 undefined is not a function:TypeScript 前端开发优势与实践指南
前端·javascript·typescript·web
行云&流水3 小时前
Vue3 Lifecycle Hooks
前端·javascript·vue.js
老虎06274 小时前
JavaWeb(苍穹外卖)--学习笔记04(前端:HTML,CSS,JavaScript)
前端·javascript·css·笔记·学习·html
三水气象台4 小时前
用户中心Vue3网页开发(1.0版)
javascript·css·vue.js·typescript·前端框架·html·anti-design-vue
烛阴4 小时前
Babel 完全上手指南:从零开始解锁现代 JavaScript 开发的超能力!
前端·javascript
CN-Dust5 小时前
[FMZ][JS]第一个回测程序--让时间轴跑起来
javascript
盛夏绽放5 小时前
Vue3 中 Excel 导出的性能优化与实战指南
vue.js·excel
全宝6 小时前
🎨前端实现文字渐变的三种方式
前端·javascript·css
yanlele6 小时前
前端面试第 75 期 - 2025.07.06 更新前端面试问题总结(12道题)
前端·javascript·面试