微前端是现代前端开发的趋势,许多企业选择将微前端架构融入其技术战略中,有些是选择现有微前端框架如 Single-SPA、Qiankun、Micro-App 或 Wujie,有些是根据自身独特的业务需求研发了定制的解决方案。
这一技术趋势的背后是前端技术的快速进化和单页面应用(SPA)开发模式的普及。
多页应用
在早期的前端开发中,网站通常采用多页面应用(MultiPage Application, MPA)的形式,每个页面都有自己独立的 HTML、JavaScript 和 CSS 文件。这种架构的一个显著特点是,当浏览器的 URL 发生变化时,浏览器会加载一个新的 HTML 页面,并随之加载相应的 JavaScript 和 CSS 资源。这导致页面不断刷新,虽然简单直接,但对于用户来说体验并不友好,尤其是在需要快速响应和交互的现代Web应用中。
单页应用
为了减少页面全局刷新,提升用户体验,单页面应用(SinglePage Web Application, SPA)应运而生。SPA 通过在一个单一的HTML页面加载所有JavaScript 和 CSS 资源,在用户交互过程中,网页不会重新加载或跳转,而是动态地重写当前页面与用户交互的部分,从而避免了页面的全面刷新。
SPA能实现局部渲染主要是基于两个技术实现:
- AJAX异步
通过AJAX技术异步请求数据,客户端可以在不刷新整个页面的情况下,与服务器交换数据,并根据返回的数据更新页面的部分内容。这种方式允许用户在网页上进行快速交互,只加载或变更需要更新的部分。
- JavaScript 路由
路由管理通常由JavaScript在前端处理,而不是服务器端。通过在客户端监听URL的变化,然后根据URL的不同展示相应的视图,而无需重新加载页面。单页面应用主要依赖两种路由模式来管理 URL 的变化:一种是基于 URL 的哈希(hash),另一种是利用 HTML5 的 History API。
微前端应用
随着业务的增长和应用的扩展,单页面应用往往逐渐演变为庞大的单体应用,这不仅使得项目难以维护,同时由于前端技术栈的快速迭代,老旧技术的技术债务也日益增加。
在这样的背景下,传统的巨石单体应用已经难以应对快速迭代和灵活部署的要求。微前端架构应运而生,在微前端架构下,一个大型单一的前端应用被拆分成多个小型、独立的子应用,这些子应用负责应用的一部分功能,可以独立开发、部署、运行,并且可以使用不同的技术栈,从而带来更加灵活高效的项目开发和管理。
微前端架构本质上依然采用单页面应用的形式,即在一个单一的 HTML 文件中加载多个 JavaScript 和 CSS 资源。然而,它通过精巧的路由和应用生命周期管理,以及不可缺少的隔离和共享机制,能够将多个独立开发的子应用集成到一个协调一致的用户界面中。
从微前端概念和产生背景出发,基于对现有微前端框架的考查,可以总结出微前端架构的设计具有以下特征:
- 子应用的独立性:独立开发、技术栈无关。
- 子应用的自治性(隔离):应用运行期间有明显的边界,不受影响。
- 共享机制:复用性、统一体验、高效协调。
这种模式不仅提高了开发效率,降低了维护难度,还使得旧系统的逐步迁移变得可行,无需重构整个应用。因此,微前端是现代Web开发中的一个重要趋势。