Waiter:微前端之间的简洁通信

简而言之:我构建了一个轻量级的 TypeScript 库,用于让微前端之间轻松通信。

无需发布/订阅,也不需要事件总线,只需简单的请求/响应模式即可完成交互

❗问题所在

如果你曾经使用过微前端架构,一定体会过让各个子应用互相通信的痛苦。最终通常会演变成以下情况:

  • 复杂难调试的事件系统
  • 各种竞态条件和时序问题
  • 处理敏感数据时的安全隐患

🛠 它是如何工作的

Waiter 允许你在应用的一部分创建"控制器",然后从其他任意位置发起请求。可以把它理解为前端内部的 API:

javascript 复制代码
// 在用户管理微前端中
const waiter = new Waiter();
waiter.createController('getUserData', (userId) => {
  return userStore.getUser(userId);
});

// 在仪表盘微前端中
const waiter = new Waiter();
const user = await waiter.request('getUserData', 123);

就是这样。无需设置,无需配置,即可使用。

🔑 主要特性

  • 零依赖 ------ Gzip 后仅几 KB
  • 原生支持 TypeScript ------ 开箱即用的完整类型安全
  • 基于 Promise ------ 完整支持 async/await 异步调用
  • 内置安全机制 ------ 可选的身份验证令牌与 AES-GCM 加密
  • 框架无关 ------ 可与 React、Vue、Angular 或原生 JS 搭配使用

🔒 安全特性(亮点)

你可以使用身份验证令牌和加密功能来保护敏感通信:

arduino 复制代码
const secureWaiter = new Waiter({
  authToken: 'secret-token',
  encryptionKey: 'your-32-char-encryption-key'
});

// 只有持有正确令牌的代码才能创建或移除控制器
// 所有传输的数据都会自动加密处理

🚀 在线演示

点击这里查看演示

该库已发布在 NPMGitHub。欢迎大家试用并提出宝贵意见!

相关推荐
小码哥_常43 分钟前
Kotlin类型魔法:Any、Unit、Nothing 深度探秘
前端
Web极客码2 小时前
深入了解WordPress网站访客意图
服务器·前端·wordpress
幺风2 小时前
Claude Code 源码分析 — Tool/MCP/Skill 可扩展工具系统
前端·javascript·ai编程
vjmap2 小时前
唯杰地图CAD图层加高性能特效扩展包发布
前端·gis
ZC跨境爬虫3 小时前
3D 地球卫星轨道可视化平台开发 Day7(AI异步加速+卫星系列精简+AI Agent自动评论)
前端·人工智能·3d·html·json
ID_180079054733 小时前
淘宝 API 上货 / 商品搬家 业务场景实现 + JSON 返回示例
前端·javascript·json
M ? A3 小时前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
vipbic3 小时前
独立开发复盘:我用 Uni-app + Strapi v5 肝了一个“会上瘾”的打卡小程序
前端·微信小程序
IT_陈寒4 小时前
Vite的热更新突然失效,原来是因为这个配置
前端·人工智能·后端
ZC跨境爬虫4 小时前
3D 地球卫星轨道可视化平台开发 Day8(分步渲染200颗卫星+ 前端分页控制)
前端·python·3d·重构·html