vue 缓存不刷新某个页面

场景是列表页有搜索条件后跳入详情页,从详情页返回列表页不刷新。

在列表和详情页设置keepAlive

//路由页

meta: {

      title: '详情页',

      keepAlive: true //此组件需要被缓存

 }

meta: {

      title: '列表',

      keepAlive: true //此组件需要被缓存

  }

//app.vue页

<router-view v-slot="{ Component }" v-if="$route.meta.keepAlive">
          <keep-alive>
                <component :is="Component" />
          </keep-alive>
      </router-view>
      <router-view v-slot="{ Component }" v-if="!$route.meta.keepAlive">
          <component :is="Component" />
      </router-view>

这种方式详情页也会被缓存, 有两个方法。

第一个方法是进入详情页时重新弹出一个页面,详情页是新页面。 详情返回列表时关闭页面,这个方式适合pc端手机端无效

//打开新页面
let routeData = router.resolve({ path: '/detail', query: { id:data.id} });
window.open(routeData.href, '_blank');


//关闭页面
window.close();

第二个方法是进入详情页后判断路由,如果从列表页进入,页面不刷新但重新获取数据。

 

watch:{
        $route(to,from){
            if(from.name=='list'){
                this.productId=this.$route.query.id
                this.getData()
            }
        }
    }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值