前端微前端架构:大项目的救命稻草还是自找麻烦?

前端微前端架构:大项目的救命稻草还是自找麻烦?

毒舌时刻

微前端?听起来就像是一群前端工程师为了显得自己很高级,特意发明的复杂术语。不就是把一个大应用拆成几个小应用嘛,至于搞得这么玄乎吗?

你以为拆成微前端就能解决所有问题?别做梦了!到时候你会发现,调试变得更麻烦了,部署变得更复杂了,甚至连样式都可能互相冲突。

为什么你需要这个

  1. 大型应用的可维护性:当你的应用变得越来越大,单靠一个团队已经无法高效维护时,微前端可以让不同团队独立开发和部署各自的模块。
  2. 技术栈的灵活性:不同的微前端可以使用不同的技术栈,比如一个模块用React,另一个模块用Vue,这样可以根据团队的专长选择最合适的技术。
  3. 独立部署:微前端可以独立部署,不需要整个应用一起发布,这样可以减少发布风险,加快发布速度。
  4. 团队协作:不同团队可以独立开发各自的微前端,减少代码冲突和沟通成本。

反面教材

// 这是一个典型的单体应用结构 import React from 'react'; import ReactDOM from 'react-dom'; import Header from './components/Header'; import Sidebar from './components/Sidebar'; import Dashboard from './components/Dashboard'; import Settings from './components/Settings'; import UserProfile from './components/UserProfile'; function App() { return ( <div className="app"> <Header /> <Sidebar /> <main> <Dashboard /> <Settings /> <UserProfile /> </main> </div> ); } ReactDOM.render(<App />, document.getElementById('root')); 

问题

  • 所有代码都在一个代码库中,随着功能增加,代码量会变得非常庞大
  • 团队协作困难,容易出现代码冲突
  • 部署风险高,任何一个小改动都需要整个应用一起发布
  • 技术栈单一,无法根据不同模块的需求选择最合适的技术

正确的做法

使用Single-SPA实现微前端

// 主应用配置 import { registerApplication, start } from 'single-spa'; // 注册微前端应用 registerApplication({ name: 'header', app: () => import('@org/header'), activeWhen: (location) => true, }); registerApplication({ name: 'dashboard', app: () => import('@org/dashboard'), activeWhen: (location) => location.pathname === '/dashboard', }); registerApplication({ name: 'settings', app: () => import('@org/settings'), activeWhen: (location) => location.pathname === '/settings', }); registerApplication({ name: 'user-profile', app: () => import('@org/user-profile'), activeWhen: (location) => location.pathname === '/user-profile', }); // 启动应用 start(); 

微前端应用示例

// dashboard微前端 import React from 'react'; import ReactDOM from 'react-dom'; import singleSpaReact from 'single-spa-react'; function Dashboard() { return ( <div className="dashboard"> <h1>Dashboard</h1> <p>Welcome to your dashboard!</p> </div> ); } const reactLifecycles = singleSpaReact({ React, ReactDOM, rootComponent: Dashboard, errorBoundary(err, info, props) { return <div>An error occurred: {err.message}</div>; }, }); export const bootstrap = reactLifecycles.bootstrap; export const mount = reactLifecycles.mount; export const unmount = reactLifecycles.unmount; 

样式隔离

/* 使用CSS Modules或Shadow DOM进行样式隔离 */ .dashboard { /* 样式只会应用到当前微前端 */ background-color: #f5f5f5; padding: 20px; } 

通信机制

// 使用自定义事件进行微前端间通信 // 发送消息 function sendMessage(message) { window.dispatchEvent(new CustomEvent('micro-frontend-message', { detail: message })); } // 接收消息 window.addEventListener('micro-frontend-message', (event) => { const message = event.detail; console.log('Received message:', message); }); 

毒舌点评

微前端确实能解决大型应用的一些问题,但它并不是银弹。如果你只是为了赶时髦而使用微前端,那你很快就会发现,它带来的麻烦比解决的问题还多。

想象一下,当你需要在多个微前端之间共享状态时,你会发现自己陷入了新的困境。你可能需要引入复杂的状态管理方案,或者使用 localStorage 这种不太可靠的方式。

还有部署问题,你需要确保所有微前端的版本兼容,否则就会出现各种奇怪的bug。更糟糕的是,当一个微前端崩溃时,可能会影响整个应用的运行。

所以,在决定使用微前端之前,先问问自己:我的应用真的大到需要微前端吗?我的团队真的需要技术栈的灵活性吗?如果答案是否定的,那还是老老实实用单体应用吧,至少调试起来方便。

当然,如果你真的需要微前端,那请务必做好规划,选择合适的框架,制定好通信机制和样式隔离方案。否则,你会发现自己掉进了一个新的坑里,而且这个坑可能比原来的还要深。

Read more

如何用腾讯云轻量应用服务器内置OpenClaw应用搭建OpenClaw并接入QQ、飞书机器人,下载skill,开启对话

如何用腾讯云轻量应用服务器内置OpenClaw应用搭建OpenClaw并接入QQ、飞书机器人,下载skill,开启对话

诸神缄默不语-个人技术博文与视频目录 如需OpenClaw下载安装、配置、部署服务可以联系:https://my.feishu.cn/share/base/form/shrcnqjFuoNiBPXjADvRhiUcB1B 我发现腾讯云买服务器可以用QQ钱包,这不得狠狠把我多年来抢的红包狠狠利用一下。 OpenClaw我之前玩了几天,现在把gateway关了,因为我感觉第一是感觉AI对于一些细微的执行逻辑还是绕不明白,而且API太慢了等得我着急,慢得我都不知道它是死了还是只是慢,不如我直接一个古法编程下去开发一个自己的工具。我本来是想拿OpenClaw当时间管理助手的,但是研究了一番感觉它作为整个人完整的时间/项目/文件系统/财务/生活管理助手的潜力还是很大的。但是,也就仅止于潜力了,跟OpenClaw绕记账怎么记实在是把我绕火大了……第二,正如网上一直宣传的那样,这玩意太耗token了,我的混元和Qwen免费额度几乎都秒爆,GLM也给我一下子烧了一大笔。我觉得这不是我的消费水平该玩的东西……主要我也确实没有什么用OpenClaw赚大钱的好idea。 但是我仍然觉得OpenClaw

TWIST2——全身VR遥操控制:采集人形全身数据后,可训练视觉base的自主策略(基于视觉观测预测全身关节位置)

TWIST2——全身VR遥操控制:采集人形全身数据后,可训练视觉base的自主策略(基于视觉观测预测全身关节位置)

前言 我司内部在让机器人做一些行走-操作任务时,不可避免的需要全身遥操机器人采集一些任务数据,而对于全身摇操控制,目前看起来效果比较好的,并不多 * 之前有个CLONE(之前本博客内也解读过),但他们尚未完全开源 * 于此,便关注到了本文要解读的TWIST2,其核心创新是:无动捕下的全身控制 PS,如果你也在做loco-mani相关的工作,欢迎私我你的一两句简介,邀你加入『七月:人形loco-mani(行走-操作)』交流群 第一部分 TWIST2:可扩展、可移植且全面的人形数据采集系统 1.1 引言与相关工作 1.1.1 引言 如TWIST2原论文所说,现有的人形机器人远程操作系统主要分为三大类: 全身控制,直接跟踪人体姿态,包括手臂、躯干和腿部在内的所有关节以统一方式进行控制(如 HumanPlus [12],TWIST [1] ———— TWIST的介绍详见此文《TWIST——基于动捕的全身遥操模仿学习:教师策略RL训练,学生策略结合RL和BC联合优化(可训练搬箱子)》 部分全身控制,

Ubuntu搭建PX4无人机仿真环境(5) —— 仿真环境搭建(以Ubuntu 22.04,ROS2 Humble,Micro XRCE-DDS Agent为例)

Ubuntu搭建PX4无人机仿真环境(5) —— 仿真环境搭建(以Ubuntu 22.04,ROS2 Humble,Micro XRCE-DDS Agent为例)

目录 * 前言 * 1. 准备 * 1.1 下载 PX4 源码 * 方式一: * 方式二: * 1.2 安装仿真依赖 * 1.3 安装 Gazebo * 2. 安装 Micro XRCE-DDS Agent * 3. 编译 PX4 * 4. 通信测试 * 5. 官方 offboard 程序 * 6. offboard 测试 * 参考 前言 本教程基于 ROS2 ,在搭建之前,需要把 ROS2、QGC 等基础环境安装配置完成。但是这块的资料相比较于 ROS1 下的少很多,不利于快速上手和后期开发,小白慎选! 小白必看: