App开发-使用keepAlive,解决页面缓存是否动态刷新的问题

1、APP页面从另一个页面返回保持原有状态

我们经常使用App都知道,比如当我们从一个搜索列表进入商品详情页面,再次从商品详情页面返回列表页面肯定会停留在上次浏览的位置,如果我们再次刷新或者回到列表顶部,这样对用户的操作体验肯定是不友好的,所以我们要首先解决这个问题。

经过查证,发现在router里面有一个keepAlive,只要我们将keepAlive设置为true,他就会帮我们自动缓存记录上次获取的DOM,而不会再次去刷新数据请求新的DOM。

在router.js里面如下设置即可。

{
  path: '/user-comment',
  name: 'userComment',
  component: () => import(/* webpackChunkName: "order" */ '@/views/Order.vue'),
  meta: {
     index: 2,
     keepAlive: true,
  },
},

2、随之产生的问题

我们刚刚对某一个页面的路由设置了keepAlive等于true,这样设置我们确实解决了从详情页面返回到列表页面定位在我们上次浏览的地方,但是新的问题产生了。我在App开发负责开发搜索功能,所以我们还是以搜索功能举例,当我从搜索首页输入关键词进行搜索的时候,发现不管我输入什么搜索词都不再起作用,搜索出来的结果都是我们第一次搜索的结果,这样的原因就是因为我们给这个页面路由设置了keepAlive等于true,因为我们上面提到了它会自动帮我们缓存当前页面的DOM,还有主要的问题就是

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值