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设置成要去的地址

刷新页面,成功!

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
在 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> ``` 这样,就可以实现三级菜单展开不会自动折叠的效果了。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值