这篇文章将为大家详细讲解有关怎么在vue2中使用keep-alive缓存多层列表页,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
路由到详情页,然后详情页加载列表页组件展现,然后在组件模块通过props:[‘id']获取数据
import Vmothod from '../page/ApiMethodTable.vue';
import VsystemParam from '../page/ApiSystemParamTable.vue';
import VsystemError from '../page/ApiSystemErrorTable.vue';
<template>
<div>
<Vmothod :id="id"></Vmothod>
<VsystemParam :id="id"></VsystemParam>
<VsystemError :id="id"></VsystemError>
</div>
</template>
但是如此以来,在返回上一层或者修改数据回跳后,因为没有页面缓存,所以页数会变成第一页,使用上很不方便。
在网上找了相关解决方案后,我试着在路由上加入了keep-alive参数。
meta: { keepAlive: true }
<keep-alive>
<router-view v-if="$route.meta.keepAlive"></router-view>
</keep-alive>
<router-view v-if="!$route.meta.keepAlive"></router-view>
这样解决了页面不缓存的问题,但跳转之后所有页面都是一模一样的数据,这就很不对了。后台发觉还要在页面初始化时加入钩子函数拉取数据
activated(){
this.getData();
}
但是发觉还是不行,上一页通过props:[‘id']传递到组件参数也会被缓存,如此以来props不能用了,只有通过在路由来传递参数。
在路由的时候带上id参数
path:'/method/:id'
然后在组件页面获取参数
self.$route.params.id
关于怎么在vue2中使用keep-alive缓存多层列表页就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。