vue 使某个组件不被 keep-alive 缓存的方法
网络编程 2021-07-04 16:46www.168986.cn编程入门
今天长沙网络推广就为大家分享一篇vue 使某个组件不被 keep-alive 缓存的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随长沙网络推广过来看看吧
提出问题
最近在做项目发现一个问题,当我使用了 keep-alive 标签后,进入了某个路由进行一系列操作,再点击浏览器后退,进入刚才的路由,页面被操作的数据没有初始化!
分析问题
这是因为 keep-alive 将路由页面缓存,所以该路由没有完成整个生命周期,没有 destroyed,重新进入也没有触发其他生命周期钩子,如 created 等。
解决问题
(1). 查看官方文档
当组件在 keep-alive 内被切换,它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行。
include - 字符串或正则表达式。只有匹配的组件会被缓存。
exclude - 字符串或正则表达式。任何匹配的组件都不会被缓存。
<!-- 逗号分隔字符串 --> <keep-alive include="a,b"> <ponent :is="view"></ponent> </keep-alive> <!-- 正则表达式 (使用 `v-bind`) --> <keep-alive :include="/a|b/"> <ponent :is="view"></ponent> </keep-alive> <!-- 数组 (使用 `v-bind`) --> <keep-alive :include="['a', 'b']"> <ponent :is="view"></ponent> </keep-alive>
匹配检查组件自身的 name 选项,如果 name 选项不可用,则匹配它的局部注册名称 (父组件 ponents 选项的键值)。匿名组件不能被匹配。
(2). 监听路由变化
使用 watch 监听路由变化,我发现监听路由只有在组件被 keep-alive 包裹时才生效,未包裹时不生效,原因不明,理解的小伙伴请留言告诉我!
watch: { '$route' (to, from) { // 对路由变化作出响应... } }
beforeRouteUpdate 这个钩子目前我发现还不能用,不知道哪里出错。
beforeRouteUpdate (to, from, next) { // react to route changes... // don't fet to call next() }
以上这篇vue 使某个组件不被 keep-alive 缓存的方法就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程