vue使用--tabs切换重复触发事件

tab越多,点击切换tab时,触发的次数越多,如果在里面渲染组件,会造成组件多次执行生命周期
在这里插入图片描述
解决方案:增加 v-if=“activeKey === pane.key” 判断,不是切换的key不渲染

<a-tabs
  v-model="activeKey"
  type="editable-card"
  @change="changeTab"
  @edit="onEdit"
>
  <a-tab-pane
    v-for="pane in panes"
    :key="pane.key"
    :tab="pane.title"
    :closable="pane.closable"
  >
    <keep-alive>
      <router-view  v-if="activeKey === pane.key"></router-view>
    </keep-alive>
  </a-tab-pane>
</a-tabs>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Ant Design Vue的a-tabs组件时,如果想在tab上添加一个开关,可以通过在a-tab-pane组件中添加一个v-if的判断来实现。具体做法是,在a-tab-pane组件中添加一个v-if="activeKey === pane.key"的判断条件,只有当当前tab的key与activeKey相等时才渲染内容。这样就可以根据需要来控制tab的开关状态。示例代码如下: ```html <a-tabs v-model="activeKey" type="editable-card" @change="changeTab" @edit="onEdit"> <a-tab-pane v-for="pane in panes" :key="pane.key" :tab="pane.title" :closable="pane.closable"> <keep-alive> <router-view v-if="activeKey === pane.key"></router-view> </keep-alive> </a-tab-pane> </a-tabs> ``` 通过在a-tab-pane组件中添加v-if="activeKey === pane.key"的判断条件,可以实现根据activeKey的值来控制tab的开关状态。只有当当前tab的key与activeKey相等时,才会渲染对应的内容。这样就可以实现在a-tabs的tab上添加开关的效果。引用提供了在Vue使用Ant Design的a-tabs组件的示例代码,引用介绍了使用vue实现tab滚动固定在顶部的方法,可以作为参考。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [antd-vue使用--tabs切换重复触发事件](https://blog.csdn.net/weixin_45377314/article/details/114387960)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [vue tab滚动到一定高度,固定在顶部,点击tab切换不同的内容操作](https://download.csdn.net/download/weixin_38553837/12924922)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值