Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Tencent/wujie
极致的微前端框架
https://github.com/Tencent/wujie
Last synced: 3 months ago
JSON representation
极致的微前端框架
- Host: GitHub
- URL: https://github.com/Tencent/wujie
- Owner: Tencent
- License: other
- Created: 2022-06-29T06:40:13.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2024-06-07T09:23:00.000Z (7 months ago)
- Last Synced: 2024-10-17T16:23:35.859Z (3 months ago)
- Language: TypeScript
- Homepage: https://wujie-micro.github.io/doc/
- Size: 848 KB
- Stars: 4,100
- Watchers: 31
- Forks: 586
- Open Issues: 395
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome - Tencent/wujie - 极致的微前端框架 (TypeScript)
- popular-dependents-lists - Tencent/wujie - 🌟 780 (Puppeteer / Tencent/wujie)
README
# wujie(无界)
无界微前端是一款基于 Web Components + iframe 微前端框架,具备成本低、速度快、原生隔离、功能强等一系列优点。
## 文档
动机:[动机](https://zhuanlan.zhihu.com/p/551206945)
文档详见:[文档](https://wujie-micro.github.io/doc/)
演示详见:[demo](https://wujie-micro.github.io/demo-main-vue/home)
## 背景
微前端已经是一个非常成熟的领域了,但开发者不管采用哪个现有方案,在适配成本、样式隔离、运行性能、页面白屏、子应用通信、子应用保活、多应用激活、vite 框架支持、应用共享等用户核心诉求都或存在问题、或无法提供支持。
Web Components 是一个浏览器原生支持的组件封装技术,可以有效隔离元素之间的样式,iframe 可以给子应用提供一个原生隔离的运行环境,相比自行构造的沙箱 iframe 提供了独立的 window、document、history、location,可以更好的和外部解耦。无界微前端采用 webcomponent + iframe 的沙箱模式,在实现原生隔离的前提下比较完善的解决了上述问题。
## 特性
1. 成本低
- 主应用使用成本低
- 子应用适配成本低
2. 速度快
- 子应用首屏打开速度快
- 子应用运行速度快
3. 原生隔离
- css 样式通过 Web Components 可以做到严格的原生隔离
- js 运行在 iframe 中做到严格的原生隔离
4. 功能强大
- 支持子应用保活
- 支持子应用嵌套
- 支持多应用激活
- 支持应用共享
- 支持去中心化通信
- 支持生命周期钩子
- 支持插件系统
- 支持 vite 框架## 快速上手
### 直接使用
- 安装
```bash
npm install wujie -S
```- 使用
```javascript
import { startApp } from "wujie";startApp({ name: "唯一id", url: "子应用路径", el: "容器", sync: true });
```### vue 框架
- 安装
```bash
# vue2 框架
npm i wujie-vue2 -S
# vue3 框架
npm i wujie-vue3 -S```
- 引入
```javascript
// vue2
import WujieVue from "wujie-vue2";
Vue.use(WujieVue);
// vue3
import WujieVue from "wujie-vue3";
app.use(WujieVue);
```- 使用
```js
```
### react 框架
- 安装
```bash
npm i wujie-react -S```
- 引入
```javascript
import WujieReact from "wujie-react";
```- 使用
```html
```
## 常见问题
[详见文档](https://wujie-micro.github.io/doc/question/#_1%E3%80%81%E8%AF%B7%E6%B1%82%E8%B5%84%E6%BA%90%E6%8A%A5%E9%94%99)
## 本地开发
运行以下脚本,可以本地开发无界微前端框架,支持实时编译调试开发。
```bash
pnpm i // 安装包依赖,务必使用pnpm
npm run start // 启动所有应用
```
## One more thing无界微前端解决方案来源于团队的无极低代码平台,通过无界微前端,存量页面和低代码页面可以丝滑的互相内嵌,欢迎体验[【腾讯无极低代码】](https://wujicode.cn)。