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,还有主要的问题就是