您好,登录后才能下订单哦!
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实现组件切换时保存原组件数据的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。