vue,vue3 keepalive没有效果,无法缓存页面include无效,keep-alive

keepalive没有效果,无法缓存页面?

问题大概是组件的name值不对应,vue2修改组件文件的name值,vue3保持组件文件名称和路由页面配置的name一致就可以了,如果vue3不想保持一致,必须手动在文件后面添加export...如下。

vue3不修改文件名称,但实现效果:

核心代码和全部代码:

javascript 复制代码
<script>
export default {
  name: 'ppidPage'
}
</script>
javascript 复制代码
<template>
  <PpidConfig />
</template>
<script setup>
import { onMounted } from 'vue'
import PpidConfig from './PpidConfig.vue'
import { usePpidStore } from '@/store/operation/ppid.js'
const ppidStore = usePpidStore()
onMounted(async () => {
  await ppidStore.getAllUnits()
})
</script>
<script>
export default {
  name: 'ppidPage'
}
</script>

keepalive文件:

javascript 复制代码
<template>
  <section class="app-main">
    <router-view v-slot="{ Component }">
      <transition name="fade-transform" mode="out-in">
        <keep-alive :include="cachedViews">
          <component :is="Component" :key="key" />
        </keep-alive>
      </transition>
    </router-view>
  </section>
</template>

<script setup>
import { computed } from 'vue'
import { useTagsViewStore } from '@/store/tagsView'
import { useRoute } from 'vue-router';
const route = useRoute();
const tagsViewStore = useTagsViewStore()

// 缓存的路由组件名称列表
const cachedViews = computed(() => {
  console.log('当前缓存页面:', tagsViewStore.cachedViews)
  // return tagsViewStore.cachedViews
  return tagsViewStore.cachedViews.filter(item => {
    if (route.name == item && !route.meta.keepAlive) {  //keepAlive为false不缓存
      return false;
    } else {
      return true;
    }
  })
})
</script>

<style scoped></style>

router.js页面配置:

javascript 复制代码
{
      path: 'ppid-config',
      permission: 'Operation.PPID',
      component: () => import('@/views/operation/ppid/ppidPage.vue'),
      name: 'ppidPage',
      meta: {
        title: t('route.operation.ppidConfig'),
        keepAlive: true
      }
    },

vue3 setup组件的name值无法修改,最终的name值会跟文件名称生成一致的。

vue2中可以动态修改组件name值,如下位置:

javascript 复制代码
<script lang="ts">
export default {
  name: 'User',    //修改组件的name值
  data(){
    return {
    }
  }
}
</script>

vue官网文档说明:

其他

存在transition组件的写法:

javascript 复制代码
<router-view v-slot="{ Component }" v-show="$route.meta.keepAlive">
      <transition name="fade-transform" mode="out-in">
        <keep-alive :include="cachedViews">
          <component :is="Component" :key="key" />
        </keep-alive>
      </transition>
    </router-view>
    <router-view v-slot="{ Component }" v-if="!$route.meta.keepAlive">
      <transition name="fade-transform" mode="out-in">
        <component :is="Component" :key="key" />
      </transition>
    </router-view>

相关链接:

https://cn.vuejs.org/guide/built-ins/keep-alive.html

vue3 keep-alive include失效问题_<router-view> <template #default="{ component, rou-CSDN博客

相关推荐
JIngJaneIL26 分钟前
篮球论坛|基于SprinBoot+vue的篮球论坛系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·篮球论坛系统
程序猿阿伟2 小时前
《首屏加载优化手册:Vue3+Element Plus项目提速的技术细节》
前端·javascript·vue.js
麦麦大数据2 小时前
D030知识图谱科研文献论文推荐系统vue+django+Neo4j的知识图谱|论文本文相似度推荐|协同过滤
vue.js·爬虫·django·知识图谱·科研·论文文献·相似度推荐
fruge3 小时前
Vue Pinia 状态管理实战指南
前端·vue.js·ubuntu
绝无仅有4 小时前
某教育大厂面试题解析:MySQL索引、Redis缓存、Dubbo负载均衡等
vue.js·后端·面试
sean4 小时前
开发一个自己的 claude code
前端·后端·ai编程
用户21411832636024 小时前
dify案例分享-用 Dify 一键生成教学动画 HTML!AI 助力,3 分钟搞定专业级课件
前端
没逛够5 小时前
Vue 自适应高度表格
javascript·vue.js·elementui
太过平凡的小蚂蚁6 小时前
Kotlin 协程中常见的异步返回与控制方式(速览)
开发语言·前端·kotlin
小丁爱养花6 小时前
Redis 内部编码/单线程模型/string
数据库·redis·缓存·1024程序员节