Skip to content

Commit 142effd

Browse files
JavaLionLigitee-org
authored andcommitted
!130 feat: 动态创建组件实例时, 设置路由name为组件名 解决缓存问题
Merge pull request !130 from 玲娜贝er/dev
2 parents ebaec24 + e657a50 commit 142effd

File tree

2 files changed

+44
-3
lines changed

2 files changed

+44
-3
lines changed

src/store/modules/permission.ts

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,8 @@ import Layout from '@/layout/index.vue';
99
import ParentView from '@/components/ParentView/index.vue';
1010
import InnerLink from '@/layout/components/InnerLink/index.vue';
1111

12+
import { createCustomNameComponent } from '@/utils/createCustomNameComponent';
13+
1214
// 匹配views里面所有的.vue文件
1315
const modules = import.meta.glob('./../../views/**/*.vue');
1416
export const usePermissionStore = defineStore('permission', () => {
@@ -82,7 +84,7 @@ export const usePermissionStore = defineStore('permission', () => {
8284
} else if (route.component?.toString() === 'InnerLink') {
8385
route.component = InnerLink;
8486
} else {
85-
route.component = loadView(route.component);
87+
route.component = loadView(route.component, route.name as string);
8688
}
8789
if (route.children != null && route.children && route.children.length) {
8890
route.children = filterAsyncRouter(route.children, route, type);
@@ -153,12 +155,12 @@ export const filterDynamicRoutes = (routes: RouteRecordRaw[]) => {
153155
return res;
154156
};
155157

156-
export const loadView = (view: any) => {
158+
export const loadView = (view: any, name: string) => {
157159
let res;
158160
for (const path in modules) {
159161
const dir = path.split('views/')[1].split('.vue')[0];
160162
if (dir === view) {
161-
res = () => modules[path]();
163+
res = createCustomNameComponent(modules[path], { name });
162164
}
163165
}
164166
return res;
Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
/**
2+
* 后台返回的路由动态生成name 解决缓存问题
3+
* 感谢 @fourteendp
4+
* 详见 https://github.com/vbenjs/vue-vben-admin/issues/3927
5+
*/
6+
import { Component, defineComponent, h } from 'vue';
7+
8+
interface Options {
9+
name?: string;
10+
}
11+
12+
export function createCustomNameComponent(loader: () => Promise<any>, options: Options = {}): () => Promise<Component> {
13+
const { name } = options;
14+
let component: Component | null = null;
15+
16+
const load = async () => {
17+
try {
18+
const { default: loadedComponent } = await loader();
19+
component = loadedComponent;
20+
} catch (error) {
21+
console.error(`Cannot resolve component ${name}, error:`, error);
22+
}
23+
};
24+
25+
return async () => {
26+
if (!component) {
27+
await load();
28+
}
29+
30+
return Promise.resolve(
31+
defineComponent({
32+
name,
33+
render() {
34+
return h(component as Component);
35+
}
36+
})
37+
);
38+
};
39+
}

0 commit comments

Comments
 (0)