若依框架-已经设置了缓存的页面,在特定情境下清除缓存【拿到路由上的参数进行判断是否清除缓存刷新】

1、情境:在若依框架中每个页面设置了缓存,但是有一个功能需要从这个页面带参数去另外一个页面进行跳转,此时发现因为缓存,这个跳转的功能失效了

2、操作:在跳转之前的那个页面加载之前加一个标记

 mounted() {
    sessionStorage.setItem('custom', 'Refresh');
 }

3、在跳转离开这个第一个页面之前设置以下的代码,这段代码写在method下面,和它同级【这里有一个大坑!!!!缓存的这个sessionStorage.setItem('custom', '');里面的custom是要写你页面路由的那个名字,不是随便起的,哎,因为这个找了好久的错误!救命】

  beforeRouteLeave(to, from, next) {
    console.log('kanyixia' + to.query.casesId);
    if (!to.query.casesId) { //判断路由的参数 如果没有就把标记清空,如果有就带上标记
      sessionStorage.setItem('custom', '');
    } else {
      sessionStorage.setItem('custom', 'Refresh');
    }
    // debugger;
    if (
      to.name === 'Custom' &&
      sessionStorage.getItem('custom') === 'Refresh'
    ) {
      try {
        var cache = this.$vnode.parent.componentInstance.cache;
        var key = '';
        for (var prop in cache) {
          if (prop.lastIndexOf('custom') > 0) {
            key = prop;
          }
        }
        if (key != '') {
          delete cache[key];
        }
      } catch (error) {}
      this.$destroy();
    }
    next();
  }

4、最后在跳转的方法体中把这个标记清除

  // 跳转至第二个页面
    goCases(row) {
      let casesId = row.id;
      this.$router.push({
        path: '/cases/custom',
        // name: 'Custom',
        query: { casesId: casesId }
        // params: { noCache: true }
      });
      sessionStorage.setItem('custom', '');//这里进行清除标记
    }

转载自:若依 this.$router.push 同地址不同参,页面不刷新问题_ruoyi公共路由不同参数跳转页面不刷新-CSDN博客

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用中的代码,你可以使用全局的 `excludes` 变量来控制 keep-alive 的缓存。当你需要清除缓存刷新页面时,只需要调用 `resetKeepAliveCache` 函数,并传入需要恢复缓存的组件名。这会从 `excludes.value` 数组中移除该组件名,从而清除缓存。 另外,根据引用中的代码,你可以通过设置 `keepAlive` 属性来决定是否缓存组件。如果 `keepAlive` 为 `true`,则会使用 `<keep-alive>` 包裹组件,实现缓存的效果。如果 `keepAlive` 为 `false`,则不会包裹组件,不会进行缓存。 需要注意的是,根据引用中的代码,Vue 3 中对于 `cache` 数组的操作权限仅限于开发环境。因此,在生产环境中,对于 `cache` 数组的操作可能无效。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Vue 适时清理 keepalive 缓存方案](https://blog.csdn.net/web22050702/article/details/126431957)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [keep-alive清除缓存](https://blog.csdn.net/HuaCHen_SHan/article/details/125541945)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值