antd vue 刷新保留当前页面路由,保留选中菜单,保留menu选中操作

废话不说,上代码!

<a-menu theme="dark" mode="inline" :selectedKeys="[$route.path]">
     <a-menu-item :key="'/home'">
      <router-link to="home">
       <a-icon type="user" />
       <span>nav 1</span>
      </router-link>
     </a-menu-item>
     <a-menu-item :key="'/about'">
      <router-link to="about">
       <a-icon type="video-camera" />
       <span>nav 2</span>
      </router-link>
     </a-menu-item>
     <a-menu-item :key="'/123123'">
      <router-link to="123123">
       <a-icon type="upload" />
       <span>nav 3</span>
      </router-link>
     </a-menu-item>
    </a-menu>

重点:
1,selectedkeys要设置成$route.path地址
2,a-menu-item 的key设置成要去的地址
刷新页面,成功!
补充知识:vue根据路由刷新页面(切换菜单刷新页面)
刷新页面有两种方法:
一种是用:localtion.reload();但是这种是重新加载页面,造成一闪一闪的效果。
一种是用provide+inject,
provider/inject:简单的来说就是在父组件中通过provider来提供变量,然后在子组件中通过inject来注入变量。
需要注意的是这里不论子组件有多深,只要调用了inject那么就可以注入provider中的数据。而不是局限于只能从当前父组件的prop属性来获取数据。

  1. 在app.vue页面中加入
 <div id="app">
   <router-view v-if="isRouterAlive"></router-view>
 </div>
 provide() {
   return{
    reload: this.reload
   }
  },
  data() {
   return {
    isRouterAlive: true
   }
  },
 methods: {
   reload () {
    this.isRouterAlive = false;
    this.$nextTick(function () {
     this.isRouterAlive = true
    })
   }
  },


  1. 在菜单页面加入
inject: ['reload'], // 注入重载的功能(注入依赖)
watch: {
  //检测路由参数发生改变时,刷新当前页面 调用
  '$route': function(){
   // this.reload();
  }
 },
  1. 注意这个@click方法,里面就是调用重新加载的方法
 <el-menu-item v-if="validatenull(item[childrenKey]) && vaildRoles(item)"
          :index="item[pathKey]"
          @click="open(item)"
          :key="item[labelKey]"
          :class="{'is-active':vaildAvtive(item)}"
          >

调用this.reload()方法,即可重新加载路由刷新页面。

open(item) {
   if (this.screen <= 1) this.$store.commit("SET_COLLAPSE");
   this.$router.$avueRouter.group = item.group;
   this.$router.push({
    path: this.$router.$avueRouter.getPath({
     name: item[this.labelKey],
     src: item[this.pathKey]
    }),
    query: item.query,
   });
   this.reload();
  },

以上这篇antd vue 刷新保留当前页面路由,保留选中菜单,保留menu选中操作

原文链接请点击

这篇文章是做一个记录,我用的第二种方法,最后调用reload的时候并不是在open里面使用的而是在watch检测路由发生变化的时候使用的;

在 Ant Design VueMenu 组件中,三级菜单默认情况下是不会展开的,需要用户手动点击才能展开。如果想要实现三级菜单展开不会自动折叠,可以考虑通过编写自定义的 Menu 组件来实现。 具体实现步骤如下: 1. 创建一个自定义的 Menu 组件,继承 Ant Design VueMenu 组件。 ```javascript import { Menu } from 'ant-design-vue'; export default { name: 'CustomMenu', extends: Menu, // ... }; ``` 2. 在组件的 data 中添加一个变量,用于存储当前展开的菜单项的 key 数组。 ```javascript export default { // ... data() { return { // 存储当前展开的菜单项的 key 数组 openKeys: [], }; }, // ... }; ``` 3. 实现 Menu 组件的 open-change 事件处理方法,用于更新 openKeys 数组的值。 ```javascript export default { // ... methods: { handleMenuOpenChange(openKeys) { this.openKeys = openKeys; }, }, // ... }; ``` 4. 在 Menu 组件的模板中,将 openKeys 数组绑定到 Menu 组件的 openKeys 属性上。 ```html <template> <a-menu :open-keys="openKeys" @open-change="handleMenuOpenChange"> <slot></slot> </a-menu> </template> ``` 5. 在 Menu.Item 组件上添加一个 slot-scope 属性,用于获取当前菜单项的 key。 ```html <a-menu-item v-for="item in menuData" :key="item.key" :data="item"> <template slot-scope="{ key }"> {{ item.title }} <custom-menu v-if="item.children" :menu-data="item.children" :default-open-keys="[key]"> <template slot-scope="{ key }"> <a-menu-item v-for="child in item.children" :key="child.key" :data="child"> {{ child.title }} </a-menu-item> </template> </custom-menu> </template> </a-menu-item> ``` 6. 创建一个 CustomMenu 组件,继承 Ant Design VueMenu 组件,并将其作为三级菜单的容器组件。 ```javascript import { Menu } from 'ant-design-vue'; export default { name: 'CustomMenu', extends: Menu, // ... }; ``` 7. 在 CustomMenu 组件的 data 中添加一个变量,用于存储当前展开的菜单项的 key 数组。 ```javascript export default { // ... data() { return { // 存储当前展开的菜单项的 key 数组 openKeys: [], }; }, // ... }; ``` 8. 实现 CustomMenu 组件的 open-change 事件处理方法,用于更新 openKeys 数组的值。 ```javascript export default { // ... methods: { handleMenuOpenChange(openKeys) { this.openKeys = openKeys; }, }, // ... }; ``` 9. 在 CustomMenu 组件的模板中,将 openKeys 数组绑定到 Menu 组件的 openKeys 属性上。 ```html <template> <a-menu :open-keys="openKeys" @open-change="handleMenuOpenChange"> <slot></slot> </a-menu> </template> ``` 10. 最后,在 Menu.Item 组件上添加一个 slot-scope 属性,用于获取当前菜单项的 key,并将其传递给 CustomMenu 组件。 ```html <a-menu-item v-for="item in menuData" :key="item.key" :data="item"> <template slot-scope="{ key }"> {{ item.title }} <custom-menu v-if="item.children" :menu-data="item.children" :default-open-keys="[key]"> <template slot-scope="{ key }"> <a-menu-item v-for="child in item.children" :key="child.key" :data="child"> {{ child.title }} </a-menu-item> </template> </custom-menu> </template> </a-menu-item> ``` 这样,就可以实现三级菜单展开不会自动折叠的效果了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值