vue页签模式+keep-alive解决关闭页签后缓存组件未销毁问题

1.简介

 

vue使用页签模式,组件使用keep-alive缓存,发现页签关闭后缓存组件未销毁,只是出于非活动状态

 

2.解决

 

使用keep-alive的include属性,这个属性包含了缓存组件的名称,可以将其赋值为动态属性

页签store

export default {
    state: {
        current: layui.data('tag').current || {},//当前页签
        list: layui.data('tag').list || []//页签列表
    },
    getters:{
        /** 标签名称列表 */
        tagNames (state) {
            return state.list.map(function(tag){return tag.name})
        }
    }
}
  • list是页签对象列表
  • tagNames为页签名称列表,即要缓存的页签组件名称

 

<keep-alive v-if="isRouterAlive" :include="tagNames">
          <router-view ></router-view>
</keep-alive>
...mapGetters({
     tagNames:'tagNames'
})
  • 这样就保证了移除tag后,相应的组件名称也不会被缓存
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值