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博客

相关推荐
搜狐技术产品小编202311 分钟前
深度解析与业务实战:将 screenshot-to-code 改造为支持 React + Ant Design 的前端利器
前端·javascript·react.js·前端框架·ecmascript
Rik13 分钟前
Cursor Rules 深度玩法:从全局配置到项目级规则,让 AI 真正理解你的项目
前端·后端
weixin_4713830315 分钟前
set和map结构,减少O(n)复杂度
前端·javascript
hunteritself19 分钟前
GPT Image2 + Seedance 2.0:3 小时从剧本到 AI 互动影游,深度实测复盘
前端·数据库·人工智能·深度学习·transformer
独秀不如众秀26 分钟前
前端页面引擎协议:由浅入深——从 30 行到 vform3 的演化之路
前端
学网安的肆伍35 分钟前
【044-WEB攻防篇】PHP应用&SQL盲注&布尔回显&延时判断&报错处理&增删改查方式
前端·sql·php
八号当铺1 小时前
从 Prompt 到 AI 工程化:理解 Rules、Skills 与 Agent
前端·ai编程·cursor
didadida2621 小时前
子路径部署 Vue/React 应用偶发白屏
前端·后端
invicinble1 小时前
前端框架使用vue-cli (第五层:构建打包层--总体层介绍)
前端·vue.js·前端框架
前端那点事1 小时前
Vuex刷新数据丢失?4种持久化方案全覆盖,从零到项目落地(实战完整版)
前端·vue.js