vue使用keep-alive实现组件切换时保存原组件数据?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
使用keep-alive的过程
普通方法:直接使用keep-alive
<keep-alive>
<router-view />
</keep-alive>
效果:虽然能使上传文件组件存活,在切换组件时仍可继续上传
问题:其余各个组件都不会销毁和重新挂起,导致所有组件的内容不会更新
更好一点的方法:配置路由加以判断是否适用keep-alive
路由js:
//ManageFiles组件需要重新挂起刷新数据,而ManageUploadFile为上传文件组件,故想之存活
{
path:'files',
name:'ManageFiles',
component: () => import('../pages/course/manage/resource/files/Files'),
},
{
path:'uploadfile',
name:'ManageUploadFile',
meta:{
keepAlive:true //是否存活标志
},
component: () => import('../pages/course/manage/resource/files/UploadFile'),
},
切换组件:
<template>
<div class="manageResource">
<keep-alive>
<router-view v-if="$route.meta.keepAlive" />
</keep-alive>
<router-view v-if="!$route.meta.keepAlive" />
</div>
</template>
效果图:
(1)一开始为File组件,mounted()打印'我是File'
(2)第一次切换为UploadFile组件,mounted()打印'我是UploadFile'
(3)再次切换回File组件,mounted()再次重新打印'我是File'
(4)最后再次切换回UploadFile组件,因为它一直存活,所以不会重新触发mounted()再次重新打印'我是UploadFile'
补充知识:vue 动态组件(tabs切换)keep-alive:主要用于保留组件状态或避免重新渲染
通过keep-alive 保留数据值 填写数据时切换到其他页面,后返回当前页数据保留 ,主要用于保留组件状态或避免重新渲染
<!--动态组件-component使用-->
<div class="app">
<ul>
<li @click="currView='home'">首页</li>
<li @click="currView='abount'">关于我们</li>
</ul>
<!--通过keep-alive 保留数据值 填写数据时切换到其他页面,后返回当前页数据保留-->
<keep-alive>
<component :is="currView"></component>
</keep-alive>
</div>
<script type="text/x-Template" id="homeTemp">
<h3>首页数据</h3>
</script>
<script type="text/x-Template" id="abountTemp">
<h3>关于我们数据<input type="text"/></h3>
</script>
<script type="text/javascript">
var vm=new Vue({
el:'.app',
data:{
currView:"home"
},
components:{
"home":{
template:"#homeTemp"
},
"abount":{
template:"#abountTemp"
}
}
});
</script>
看完上述内容,你们掌握vue使用keep-alive实现组件切换时保存原组件数据的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。