antd vue Menu 缩放成三个点问题

在使用 Ant Design Vue 2.2.8 版本时,遇到使用 v-if 指令导致的问题,该问题表现为预期行为与实际不符。通过替换为 v-show 可以暂时解决问题,但要注意 v-show=false 时不完全隐藏。推荐使用 Dropdown 组件作为替代方案,以避免此类问题。
摘要由CSDN通过智能技术生成
先说一下,我也没有结局,不知道哪里的机制会触发这个。当我使用v-if就会出现这个问题,然后我尝试了v-show可以结局这个问题,但是v-show=false的时候并不是隐藏,建议自己使用Dropdown组件替代一下。antd vue Version2.2.8
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
在 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> ``` 这样,就可以实现三级菜单展开不会自动折叠的效果了。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lbchenxy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值