knowledge-微前端(多个前端应用聚合的一个应用架构体系,每个小的应用可独立运行,独立开发,独立部署上线)

1.前言

微前端,将一个大的前端应用拆分为多个小型的,独立开发的前端应用,每一个小型的应用都可以单独的开发,部署和运行。这种结构允许不同的团队使用不同的技术栈来开发应用的不同部分,提高开发的效率与灵活性。

2.实现微前端

利用现有的微前端框架来进行实现

2.1蚂蚁金服-微前端乾坤(qiankun)

乾坤继承single-spa:

  • 微应用独立部署
  • 延迟加载
  • 技术无关

乾坤提供:

  • HTML入口访问模式
  • 样式隔离
  • JS沙箱
  • Umi插件继承

具体使用,参考乾坤官方项目文档使用

GitHub - umijs/qiankun: 📦 🚀 Blazing fast, simple and complete solution for micro frontends.

2.2 腾讯开源基于webComponents和iframe-微前端无界(wujie)

无界微前端是一款基于 Web Components + iframe 微前端框架,具备成本低、速度快、原生隔离、功能强等一系列优点。

Web Components 是一个浏览器原生支持的组件封装技术,可以有效隔离元素之间的样式,iframe 可以给子应用提供一个原生隔离的运行环境,相比自行构造的沙箱 iframe 提供了独立的 window、document、history、location,可以更好的和外部解耦

原生隔离

  • css 样式通过 Web Components 可以做到严格的原生隔离
  • js 运行在 iframe 中做到严格的原生隔离

功能强大

  • 支持子应用嵌套
  • 支持多应用激活
  • 支持应用共享
  • 支持生命周期钩子
  • 支持插件系统
  • 支持 vite 框架.....等

具体使用参考官网项目文档使用

https://github.com/Tencent/wujie

3.参考

仅做学习记录,博客参考

https://juejin.cn/post/7304946949940674587?searchId=20250320100915C3170A62AD017E14E75Dhttps://juejin.cn/post/7304946949940674587?searchId=20250320100915C3170A62AD017E14E75D

微前端框架之乾坤【qiankun】 vue3+vite+qiankun(手把手搭建版)_乾坤框架-CSDN博客文章浏览阅读1.1w次,点赞58次,收藏53次。简介:qiankun是一种微前端框架,可以将多个前端应用集成为一个整体。每个子应用可以使用不同的框架和技术栈,它们之间可以相互独立开发和部署,qiankun提供了一套完整的生命周期函数和通信机制,可以让不同的子应用之间进行跨框架和跨域的通信和交互。_乾坤框架https://blog.csdn.net/m0_51400948/article/details/140438945?fromshare=blogdetail&sharetype=blogdetail&sharerId=140438945&sharerefer=PC&sharesource=2301_76671906&sharefrom=from_link

相关推荐
云水一下1 天前
Vue.js从零到精通系列(一):初识Vue——背景、环境与第一个应用
前端·javascript·vue.js
云水一下1 天前
Vue.js从零到精通系列(二):响应式核心——ref、reactive、computed与watch
前端·javascript·vue.js
放下华子我只抽RuiKe51 天前
FastAPI 全栈后端(二):路由与数据模型
前端·人工智能·react.js·前端框架·html·fastapi
lichenyang4531 天前
ArkTS 严格类型系统:我答错 2 道题后才真正搞懂的几条规则
前端
小小小小宇1 天前
定高、不定高、瀑布流虚拟列表
前端
天启HTTP1 天前
开启全局代理后网络变慢,问题出在哪
开发语言·前端·网络·tcp/ip·php
卡布鲁1 天前
Webpack 核心原理与自定义 Loader/Plugin 实战
前端·javascript
智码看视界1 天前
Web Storage 的无障碍实践与工程化应用
前端·javascript·web
孟陬1 天前
国外技术周刊 #140:在 Jeff Bezos 的私密 Campfire 峰会上,我学到了关于亿万富翁的事
前端·后端
槑有老呆1 天前
Bun:一个让 Node 开发者原地起飞的 JS/TS 运行时
前端