@lvetechs/micro-app 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +243 -0
- package/package.json +48 -0
package/README.md
ADDED
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
# @lvetechs/micro-app
|
|
2
|
+
|
|
3
|
+
轻量级微前端框架,支持函数式实例化和组件式实例化两种模式。
|
|
4
|
+
|
|
5
|
+
## 安装
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
npm install @lvetechs/micro-app
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## 依赖
|
|
12
|
+
|
|
13
|
+
本库依赖以下 peerDependencies:
|
|
14
|
+
|
|
15
|
+
```json
|
|
16
|
+
{
|
|
17
|
+
"peerDependencies": {
|
|
18
|
+
"react": ">=16.8.0",
|
|
19
|
+
"react-dom": ">=16.8.0"
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
## 两种使用模式
|
|
25
|
+
|
|
26
|
+
### 模式一:函数式实例化
|
|
27
|
+
|
|
28
|
+
使用 `createMicroApp` 函数创建微应用服务实例,通过返回的实例方法控制应用。
|
|
29
|
+
|
|
30
|
+
```tsx
|
|
31
|
+
import { createMicroApp } from '@lvetechs/micro-app'
|
|
32
|
+
|
|
33
|
+
// 1. 创建微应用服务
|
|
34
|
+
const microApp = createMicroApp({
|
|
35
|
+
apps: [
|
|
36
|
+
{
|
|
37
|
+
name: 'react-app',
|
|
38
|
+
entry: 'http://localhost:3001',
|
|
39
|
+
container: '#react-app-container',
|
|
40
|
+
mode: 'iframe',
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
name: 'vue-app',
|
|
44
|
+
entry: 'http://localhost:3002',
|
|
45
|
+
container: '#vue-app-container',
|
|
46
|
+
mode: 'iframe',
|
|
47
|
+
},
|
|
48
|
+
],
|
|
49
|
+
// 状态变化回调
|
|
50
|
+
onStatusChange: (name, status) => {
|
|
51
|
+
console.log(`[${name}] 状态变化: ${status}`)
|
|
52
|
+
},
|
|
53
|
+
// 错误回调
|
|
54
|
+
onError: (error, appName) => {
|
|
55
|
+
console.error(`[${appName}] 错误:`, error)
|
|
56
|
+
},
|
|
57
|
+
// 加载完成回调
|
|
58
|
+
onLoad: (appName) => {
|
|
59
|
+
console.log(`[${appName}] 加载完成`)
|
|
60
|
+
},
|
|
61
|
+
})
|
|
62
|
+
|
|
63
|
+
// 2. 启动所有应用
|
|
64
|
+
microApp.start()
|
|
65
|
+
|
|
66
|
+
// 3. 或启动指定应用
|
|
67
|
+
microApp.startApp('react-app')
|
|
68
|
+
|
|
69
|
+
// 4. 停止指定应用
|
|
70
|
+
microApp.stopApp('react-app')
|
|
71
|
+
|
|
72
|
+
// 5. 重启指定应用
|
|
73
|
+
microApp.restartApp('vue-app')
|
|
74
|
+
|
|
75
|
+
// 6. 获取单个应用实例
|
|
76
|
+
const app = microApp.getApp('react-app')
|
|
77
|
+
if (app) {
|
|
78
|
+
app.onStatusChange((status, info) => {
|
|
79
|
+
console.log('状态变化:', status)
|
|
80
|
+
})
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
// 7. 监听所有应用状态变化
|
|
84
|
+
const unsubscribe = microApp.onAppChange((name, status) => {
|
|
85
|
+
console.log(`[全局监听] ${name}: ${status}`)
|
|
86
|
+
})
|
|
87
|
+
|
|
88
|
+
// 8. 销毁(在组件卸载时调用)
|
|
89
|
+
microApp.destroy()
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
详细示例见:`example/FunctionalExample.tsx`
|
|
93
|
+
|
|
94
|
+
---
|
|
95
|
+
|
|
96
|
+
### 模式二:组件式实例化
|
|
97
|
+
|
|
98
|
+
使用 `MicroApp` 或 `SingleMicroApp` 组件直接在页面中使用。
|
|
99
|
+
|
|
100
|
+
#### 使用 MicroApp 组件(管理多个子应用)
|
|
101
|
+
|
|
102
|
+
```tsx
|
|
103
|
+
import { MicroApp } from '@lvetechs/micro-app'
|
|
104
|
+
|
|
105
|
+
function App() {
|
|
106
|
+
const apps = [
|
|
107
|
+
{
|
|
108
|
+
name: 'react-app',
|
|
109
|
+
entry: 'http://localhost:3001',
|
|
110
|
+
container: '#react-app-container',
|
|
111
|
+
mode: 'iframe',
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
name: 'vue-app',
|
|
115
|
+
entry: 'http://localhost:3002',
|
|
116
|
+
container: '#vue-app-container',
|
|
117
|
+
mode: 'iframe',
|
|
118
|
+
},
|
|
119
|
+
]
|
|
120
|
+
|
|
121
|
+
return (
|
|
122
|
+
<MicroApp
|
|
123
|
+
apps={apps}
|
|
124
|
+
onStatusChange={(name, status) => {
|
|
125
|
+
console.log(`[${name}] 状态变化: ${status}`)
|
|
126
|
+
}}
|
|
127
|
+
onError={(error, appName) => {
|
|
128
|
+
console.error(`[${appName}] 错误:`, error)
|
|
129
|
+
}}
|
|
130
|
+
onLoad={(appName) => {
|
|
131
|
+
console.log(`[${appName}] 加载完成`)
|
|
132
|
+
}}
|
|
133
|
+
>
|
|
134
|
+
{/* 主应用内容 */}
|
|
135
|
+
<div>这是主应用</div>
|
|
136
|
+
</MicroApp>
|
|
137
|
+
)
|
|
138
|
+
}
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
#### 使用 SingleMicroApp 组件(管理单个子应用)
|
|
142
|
+
|
|
143
|
+
```tsx
|
|
144
|
+
import { SingleMicroApp } from '@lvetechs/micro-app'
|
|
145
|
+
|
|
146
|
+
function App() {
|
|
147
|
+
return (
|
|
148
|
+
<SingleMicroApp
|
|
149
|
+
name="remote-app"
|
|
150
|
+
entry="http://localhost:3001"
|
|
151
|
+
container="#app-container"
|
|
152
|
+
mode="iframe"
|
|
153
|
+
onStatusChange={(status) => console.log(status)}
|
|
154
|
+
onLoad={() => console.log('加载完成')}
|
|
155
|
+
loading={<div>加载中...</div>}
|
|
156
|
+
/>
|
|
157
|
+
)
|
|
158
|
+
}
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
详细示例见:`example/ComponentExample.tsx`
|
|
162
|
+
|
|
163
|
+
---
|
|
164
|
+
|
|
165
|
+
## API 参考
|
|
166
|
+
|
|
167
|
+
### 类型定义
|
|
168
|
+
|
|
169
|
+
#### SubAppConfig
|
|
170
|
+
|
|
171
|
+
| 属性 | 类型 | 必填 | 说明 |
|
|
172
|
+
|------|------|------|------|
|
|
173
|
+
| name | string | 是 | 应用名称,唯一标识 |
|
|
174
|
+
| entry | string | 否 | 远程应用入口 URL |
|
|
175
|
+
| container | string \| HTMLElement | 是 | 挂载容器 DOM 或选择器 |
|
|
176
|
+
| mode | 'iframe' \| 'dynamic' | 否 | 加载模式,默认 iframe |
|
|
177
|
+
| priority | number | 否 | 优先级,数值越大越先加载 |
|
|
178
|
+
| enabled | boolean | 否 | 是否启用,默认 true |
|
|
179
|
+
|
|
180
|
+
#### MicroAppStatus
|
|
181
|
+
|
|
182
|
+
| 状态 | 说明 |
|
|
183
|
+
|------|------|
|
|
184
|
+
| idle | 空闲:应用还未启动过 |
|
|
185
|
+
| starting | 启动中:应用正在初始化 |
|
|
186
|
+
| running | 运行中:应用正常运行 |
|
|
187
|
+
| error | 错误:应用遇到问题 |
|
|
188
|
+
| stopped | 已停止:应用已被停止 |
|
|
189
|
+
|
|
190
|
+
### MicroAppService 接口
|
|
191
|
+
|
|
192
|
+
| 方法 | 说明 |
|
|
193
|
+
|------|------|
|
|
194
|
+
| start() | 启动所有应用 |
|
|
195
|
+
| stop() | 停止所有应用 |
|
|
196
|
+
| startApp(name) | 启动指定应用 |
|
|
197
|
+
| stopApp(name) | 停止指定应用 |
|
|
198
|
+
| restartApp(name) | 重启指定应用 |
|
|
199
|
+
| getApp(name) | 获取指定应用实例 |
|
|
200
|
+
| getAllApps() | 获取所有应用实例 |
|
|
201
|
+
| onAppChange(callback) | 监听所有应用状态变化 |
|
|
202
|
+
| onStatusChange(name, callback) | 监听指定应用状态变化 |
|
|
203
|
+
| destroy() | 销毁实例 |
|
|
204
|
+
|
|
205
|
+
### MicroAppInstance 接口
|
|
206
|
+
|
|
207
|
+
| 方法 | 说明 |
|
|
208
|
+
|------|------|
|
|
209
|
+
| name | 应用名称 |
|
|
210
|
+
| getStatus() | 获取应用状态 |
|
|
211
|
+
| getInfo() | 获取应用信息 |
|
|
212
|
+
| start() | 启动应用 |
|
|
213
|
+
| stop() | 停止应用 |
|
|
214
|
+
| restart() | 重启应用 |
|
|
215
|
+
| updateStatus(status, error?) | 更新状态 |
|
|
216
|
+
| onStatusChange(callback) | 订阅状态变化 |
|
|
217
|
+
| checkHealth() | 健康检查 |
|
|
218
|
+
|
|
219
|
+
## 容器要求
|
|
220
|
+
|
|
221
|
+
无论是函数式还是组件式,都需要提前在页面中准备好容器 DOM:
|
|
222
|
+
|
|
223
|
+
```html
|
|
224
|
+
<!-- 函数式需要手动创建容器 -->
|
|
225
|
+
<div id="react-app-container"></div>
|
|
226
|
+
<div id="vue-app-container"></div>
|
|
227
|
+
|
|
228
|
+
<!-- 组件式会自动创建,但容器选择器需要匹配配置 -->
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
## 打包
|
|
232
|
+
|
|
233
|
+
```bash
|
|
234
|
+
# 构建
|
|
235
|
+
npm run build
|
|
236
|
+
|
|
237
|
+
# 开发模式(监听文件变化)
|
|
238
|
+
npm run dev
|
|
239
|
+
```
|
|
240
|
+
|
|
241
|
+
## License
|
|
242
|
+
|
|
243
|
+
MIT
|
package/package.json
ADDED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@lvetechs/micro-app",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "轻量级微前端框架 - 支持函数式和组件式实例化",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "dist/index.js",
|
|
7
|
+
"module": "dist/index.mjs",
|
|
8
|
+
"types": "dist/index.d.ts",
|
|
9
|
+
"files": [
|
|
10
|
+
"dist"
|
|
11
|
+
],
|
|
12
|
+
"peerDependencies": {
|
|
13
|
+
"react": "^18.2.0",
|
|
14
|
+
"react-dom": "^18.2.0",
|
|
15
|
+
"react-router-dom": "^6.30.3"
|
|
16
|
+
},
|
|
17
|
+
"devDependencies": {
|
|
18
|
+
"@types/react": "^18.2.66",
|
|
19
|
+
"@types/react-dom": "^18.2.22",
|
|
20
|
+
"@typescript-eslint/eslint-plugin": "^7.2.0",
|
|
21
|
+
"@typescript-eslint/parser": "^7.2.0",
|
|
22
|
+
"@vitejs/plugin-react": "^4.2.1",
|
|
23
|
+
"autoprefixer": "^10.4.19",
|
|
24
|
+
"eslint": "^8.57.0",
|
|
25
|
+
"eslint-plugin-react-hooks": "^4.6.0",
|
|
26
|
+
"eslint-plugin-react-refresh": "^0.4.6",
|
|
27
|
+
"postcss": "^8.4.38",
|
|
28
|
+
"tailwindcss": "^3.4.3",
|
|
29
|
+
"typescript": "^5.2.2",
|
|
30
|
+
"vite": "^5.2.0",
|
|
31
|
+
"vite-plugin-dts": "^3.9.1"
|
|
32
|
+
},
|
|
33
|
+
"keywords": [
|
|
34
|
+
"micro-frontend",
|
|
35
|
+
"microapp",
|
|
36
|
+
"react",
|
|
37
|
+
"iframe"
|
|
38
|
+
],
|
|
39
|
+
"author": "",
|
|
40
|
+
"license": "MIT",
|
|
41
|
+
"scripts": {
|
|
42
|
+
"dev": "vite",
|
|
43
|
+
"build": "tsc && vite build",
|
|
44
|
+
"build:lib": "tsc && vite build --mode lib",
|
|
45
|
+
"preview": "vite preview",
|
|
46
|
+
"lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0"
|
|
47
|
+
}
|
|
48
|
+
}
|