<template>
<router-view v-slot="{ Component, route }">
<keep-alive :include="['ComponentName']">
<component :is="Component" :key="route.name" />
</keep-alive>
</router-view>
</template>
vue3
使用 keep-alive
缓存页面时,如果需要使用 include / exclude
参数,那么就要用到组件名称。如果用 setup
语法糖书写时无法直接获取组件名,此时想要设置组件 name
的话有如下方法:
1. 多写一个script标签,并设置组件名:
<script>
export default {
name: "ComponentName",
}
</script>
2. 通过插件扩展:
安装插件:
yarn add vite-plugin-vue-setup-extend -D
或
npm i vite-plugin-vue-setup-extend -D
使用插件:
先引入
import { defineConfig, Plugin } from 'vite'
import vue from '@vitejs/plugin-vue'
import vueSetupExtend from 'vite-plugin-vue-setup-extend'
export default defineConfig({
plugins: [vue(), vueSetupExtend()],
})
然后便可以设置name属性
<template>
<div>hello world {{ a }}</div>
</template>
<script lang="ts" setup name="ComponentName">
const a = 1
</script>
标签:vue,extend,plugin,setup,alive,vue3,组件,vite
From: https://www.cnblogs.com/lpkshuai/p/17654287.html