mirror of
https://github.com/jxxghp/MoviePilot-Frontend.git
synced 2026-05-12 02:21:06 +08:00
优化 Vite 配置,更新共享库列表,移除不必要的 Rollup 选项,并简化远程模块加载逻辑,提升代码可读性和维护性。
This commit is contained in:
@@ -36,13 +36,6 @@ export default defineConfig({
|
||||
target: 'esnext', // 必须设置为esnext以支持顶层await
|
||||
minify: false, // 开发阶段建议关闭混淆
|
||||
cssCodeSplit: true, // 改为true以便能分离样式文件
|
||||
rollupOptions: {
|
||||
output: {
|
||||
manualChunks: {
|
||||
'vuetify-lib': ['vuetify'] // 将vuetify单独分离出来
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
css: {
|
||||
preprocessorOptions: {
|
||||
|
||||
@@ -6,55 +6,12 @@ import {
|
||||
// @ts-ignore
|
||||
} from 'virtual:__federation__'
|
||||
|
||||
// 扩展全局接口,添加federation所需的共享作用域
|
||||
declare global {
|
||||
interface Window {
|
||||
__rf_placeholder__shareScope?: Record<string, any>
|
||||
vue?: any
|
||||
vuetify?: any
|
||||
pinia?: any
|
||||
'vue-i18n'?: any
|
||||
'vue-router'?: any
|
||||
axios?: any
|
||||
}
|
||||
}
|
||||
|
||||
// 定义远程模块接口
|
||||
interface RemoteModule {
|
||||
id: string
|
||||
url: string
|
||||
}
|
||||
|
||||
/**
|
||||
* 初始化共享作用域
|
||||
*/
|
||||
function initShareScope() {
|
||||
// 确保全局共享作用域存在
|
||||
if (!window.__rf_placeholder__shareScope) {
|
||||
window.__rf_placeholder__shareScope = {}
|
||||
}
|
||||
// 为共享模块设置默认作用域
|
||||
const shared = ['vue', 'vuetify', 'pinia', 'vue-i18n', 'vue-router', 'axios']
|
||||
shared.forEach(lib => {
|
||||
if (window.__rf_placeholder__shareScope) {
|
||||
window.__rf_placeholder__shareScope[lib] = { default: { get: () => (window as any)[lib] } }
|
||||
}
|
||||
})
|
||||
console.log('已初始化共享作用域:', window.__rf_placeholder__shareScope)
|
||||
}
|
||||
|
||||
/**
|
||||
* 添加一个dummy远程模块以解决生产环境中的共享作用域问题
|
||||
*/
|
||||
function addDummyRemote() {
|
||||
__federation_method_setRemote('dummy', {
|
||||
url: () => Promise.resolve(''),
|
||||
format: 'esm',
|
||||
from: 'vite',
|
||||
shareScope: 'default',
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* 加载远程组件
|
||||
* @param id 远程模块ID
|
||||
@@ -83,13 +40,6 @@ async function fetchRemoteModules(): Promise<RemoteModule[]> {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 生成唯一的版本标记用于防止缓存
|
||||
*/
|
||||
function generateVersionTag(): string {
|
||||
return `v=${Date.now()}`
|
||||
}
|
||||
|
||||
/**
|
||||
* 动态注入Federation Remote模块
|
||||
* @param modules 远程模块列表
|
||||
@@ -105,17 +55,10 @@ function injectRemoteModule(module: RemoteModule): void {
|
||||
if (apiBase.endsWith('/')) {
|
||||
apiBase = apiBase.slice(0, -1)
|
||||
}
|
||||
|
||||
// 添加版本标记防止缓存
|
||||
const versionTag = generateVersionTag()
|
||||
const remoteUrl = `${baseUrl.origin}/${apiBase}${module.url}`
|
||||
const urlWithVersion = remoteUrl.includes('?') ? `${remoteUrl}&${versionTag}` : `${remoteUrl}?${versionTag}`
|
||||
|
||||
__federation_method_setRemote(module.id, {
|
||||
url: () => Promise.resolve(urlWithVersion),
|
||||
url: () => Promise.resolve(`${baseUrl.origin}/${apiBase}${module.url}`),
|
||||
format: 'esm',
|
||||
from: 'vite',
|
||||
shareScope: 'default',
|
||||
})
|
||||
console.log('已注入远程模块:', module)
|
||||
}
|
||||
@@ -125,12 +68,6 @@ function injectRemoteModule(module: RemoteModule): void {
|
||||
*/
|
||||
export async function loadRemoteComponents(): Promise<void> {
|
||||
try {
|
||||
// 初始化共享作用域
|
||||
initShareScope()
|
||||
|
||||
// 添加dummy远程模块解决生产环境问题
|
||||
addDummyRemote()
|
||||
|
||||
// 获取远程模块列表
|
||||
const modules = await fetchRemoteModules()
|
||||
|
||||
|
||||
@@ -38,7 +38,7 @@ export default defineConfig({
|
||||
remotes: {
|
||||
// 动态remotes将在运行时注入
|
||||
},
|
||||
shared: ['vue', 'vuetify', 'pinia', 'vue-i18n', 'vue-router', 'axios'],
|
||||
shared: ['vue', 'vuetify', 'vuetify/styles'],
|
||||
}),
|
||||
VitePWA({
|
||||
injectRegister: 'script',
|
||||
|
||||
Reference in New Issue
Block a user