文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue如何使用keep-alive后清除缓存

2023-06-20 20:31

关注

小编给大家分享一下vue如何使用keep-alive后清除缓存,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

什么是keepalive?

在平常开发中,有部分组件没有必要多次初始化,这时,我们需要将组件进行持久化,使组件的状态维持不变,在下一次展示时,也不会进行重新初始化组件。

也就是说,keepalive 是 Vue 内置的一个组件,可以使被包含的组件保留状态,或避免重新渲染 。也就是所谓的组件缓存

基本用法

<keep-alive>    <component />  //你的组件</keep-alive>

需求:从列表页进入详情页,再返回列表页时保留查询条件,但在切换其他tab时,清空查询条件。

解决:保留查询条件很简单,直接引入keep-alive,但是清除的话,vue本身没有api直接清除,所以要单独处理。

参考文章:http://aspedrom.com/5HD5

router/index,拦截路由并做处理:

beforeRouteLeave:function(to, from, next){    // 增加离开路由时清除keep-alive    if (from && from.meta.rank && to.meta.rank && from.meta.rank == to.meta.rank)    {//此处判断是如果返回上一层,你可以根据自己的业务更改此处的判断逻辑,酌情决定是否摧毁本层缓存。        if (this.$vnode && this.$vnode.data.keepAlive)        {            if (this.$vnode.parent && this.$vnode.parent.componentInstance && this.$vnode.parent.componentInstance.cache)            {                if (this.$vnode.componentOptions)                {                    var key = this.$vnode.key == null                                ? this.$vnode.componentOptions.Ctor.cid + (this.$vnode.componentOptions.tag ? `::${this.$vnode.componentOptions.tag}` : '')                                : this.$vnode.key;                    var cache = this.$vnode.parent.componentInstance.cache;                    var keys  = this.$vnode.parent.componentInstance.keys;                    if (cache[key])                    {                        if (keys.length) {                            var index = keys.indexOf(key);                            if (index > -1) {                                keys.splice(index, 1);                            }                        }                        delete cache[key];                    }                }            }        }        this.$destroy();    }    next();},

同时在路由中添加meta:

{    // 账号列表    path: '/account',    name: 'account',    component: () => import('../views/account/index.vue'),    meta: { title: '账号列表' ,rank:1.5}  },  {    // 添加账号    path: '/accountadd',    name: 'accountadd',    component: () => import('../views/account/add.vue'),    meta: { title: '添加账号' ,rank:2.5}  },  {    // 编辑账号    path: '/accountedit/:id',    name: 'accountedit',    component: () => import('../views/account/add.vue'),    meta: { title: '编辑账号' ,rank:2.5}  },  {    // 角色列表    path: '/role',    name: 'role',    component: () => import('../views/role/index.vue'),    meta: { title: '角色列表' ,rank:1.5}  },

以上是“vue如何使用keep-alive后清除缓存”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯