vue-router 切换tab标签关闭时缓存问题方案

本文介绍如何在Vue项目中配置路由组件的缓存机制。通过设置`keepAlive`属性为`true`或`false`来控制组件是否需要被缓存,并展示了具体的代码实现方式。

在router入口页面加上 keepAlive: true // 需要被缓存  false则不需要

  {
          path: 'fundProListG',
          component: resolve => require(['@/pages/product/fundPros/fundTab/fundTab.vue'], resolve),
          title: '基金首页',
          redirect: 'fundProListG/fundProListG',
          meta: {
            keepAlive: false // 不需要被缓存
          },
          children: [{
            path: 'fundProListG',
            component: resolve => require(['@/pages/product/fundPros/fundProListG.vue'], resolve),
            meta: {
              keepAlive: true // 需要被缓存
            }
          },{
            path: 'fungAdm',
            component: resolve => require(['@/pages/product/fundPros/fungAdm.vue'], resolve),
            meta: {
              keepAlive: true // 需要被缓存
            }
          }]
        },

App.vue (你在哪写的那个<router-view ></router-view>标签就在哪改动)

 

<keep-alive>
    <router-view v-if="$route.meta.keepAlive"></router-view>
    </keep-alive>
    <router-view v-if="!$route.meta.keepAlive"></router-view>

当点关闭标签的时候如果不想当前页面缓存 加上

接着遇到了第一次缓存第二次改为false后打开不缓存了   在关闭标签页面 加上这个

### 实现 Vue RouterTab 组件嵌入 Iframe 并缓存 为了实现在 `Vue Router` 中使用 `tab` 组件嵌入 `iframe` 并实现其内部页面的缓存效果,可以从以下几个方面着手: #### 使用 `keep-alive` 缓存组件实例 在 Vue 中,`<keep-alive>` 是一个内置组件,用于包裹动态组件,并缓存活动的组件实例而是销毁它们。当切换到其他标签页,当前标签页的内容会被重新加载。 ```html <!-- App.vue --> <template> <div id="app"> <router-view v-slot="{ Component }"> <keep-alive> <component :is="Component" /> </keep-alive> </router-view> </div> </template> ``` #### 创建带有 iframe 的自定义组件 创建一个新的名为 `IframeComponent` 的组件来封装 `iframe` 标签及其属性设置[^1]。 ```html <!-- src/components/IframeComponent.vue --> <template> <iframe ref="iframe" :src="naviurl" :height="tableHeight" style="width: 100%; border:none;" scrolling="auto" class="iframe" ></iframe> </template> <script> export default { name: 'IframeComponent', props:{ naviurl: { type: String, required: true }, tableHeight: { type: String, default: '600px' } } } </script> ``` #### 配置全局 iframe 缓存逻辑 通过配置文件中的常量和函数管理哪些页面应该被缓存以及如何处理这些缓存的数据[^2]。 ```javascript // src/utils/iframes/iframes-config.js import { iframePageList } from '@/utils' /** 是否启用全局iframes缓存组件 */ export const IFRAMES_ENABLE = true; const IFRAMES_PAGE = { ...iframePageList() }; export function PAGE_LIST() { return IFRAMES_PAGE; } ``` #### 控制 tab 显示与隐藏而刷新 iframe 页面 利用 `$route.path` 来判断当前路径是否等于某个特定项的路径,从而决定该 `iframe` 是否可见[^3]。 ```html <div v-for="(item, index) in tabs" :key="index"> <!-- 只有当路由匹配才显示对应的 iframe --> <iframe-component v-if="$route.path === item.path" :naviurl="item.url" /> </div> ``` #### 结合 vue-router-tab 插件简化操作 如果希望进一步优化体验,则可以考虑引入专门针对多标签场景设计的插件如 `vue-router-tab`[^4]。 ```bash npm install --save @chenfengyuan/vue-router-tab ``` 安装完成后,在项目中注册此插件即可享受更便捷的功能支持。 ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值