Merge branch 'jxxghp:v2' into v2

This commit is contained in:
Seed680
2025-05-09 09:21:10 +08:00
committed by GitHub
4 changed files with 9 additions and 81 deletions

View File

@@ -80,13 +80,6 @@ export default defineConfig({
target: 'esnext', // 必须设置为esnext以支持顶层await
minify: false, // 开发阶段建议关闭混淆
cssCodeSplit: true, // 改为true以便能分离样式文件
rollupOptions: {
output: {
manualChunks: {
'vuetify-lib': ['vuetify'] // 将vuetify单独分离出来
}
}
}
},
css: {
preprocessorOptions: {

View File

@@ -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: {

View File

@@ -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()

View File

@@ -35,10 +35,15 @@ export default defineConfig({
federation({
name: 'MoviePilot',
filename: 'remoteEntry.js',
// @ts-ignore
remotes: {
// 动态remotes将在运行时注入
dummy: {
external: '',
format: 'var',
},
},
shared: ['vue', 'vuetify', 'pinia', 'vue-i18n', 'vue-router', 'axios'],
shared: ['vue', 'vuetify'],
}),
VitePWA({
injectRegister: 'script',
@@ -167,8 +172,8 @@ export default defineConfig({
minify: 'terser',
terserOptions: {
compress: {
drop_console: false,
drop_debugger: false,
drop_console: true,
drop_debugger: true,
},
},
chunkSizeWarningLimit: 5000,