Generator 的天然挂起特性是微前端懒加载的底层支撑,其 yield/next 机制实现按需触发、状态可溯、流程可控的跨应用资源加载,配合调度器统一管理时机、错误与上下文。
微前端中跨应用资源加载常面临时机不可控、依赖链断裂、错误隔离难等问题。Generator 的 yield 暂停 + next 恢复 机制,恰好提供了一种“按需触发、状态可溯、流程可控”的执行模型——它不主动执行异步逻辑,而是把加载动作封装为暂停点,由宿主应用在合适时机(如路由就绪、权限校验通过、网络空闲时)调用 next() 推进,从而将加载控制权从模块内部上收至架构层。
底座不是封装一个工具函数,而是定义一套可组合、可中断、可注入上下文的 Generator 协议:
function* loadAppA() { yield fetchManifest(); yield loadScript('app-a.js'); yield mountApp(); },每个 yield 对应一个可观察、可重试、可超时的原子操作next(),甚至可插入中间件(如鉴权检查、CDN 切换、灰度分流){ type: 'script', url: '...', integrity: '...' },而非原始 Promise,使宿主能做预检(如 CSP 校验、SRI 验证)、缓存决策或降级处理yield { error: 'timeout', retry: true, fallback: 'stub-ui' },让调度器统一处理重试、兜底、上报,避免子应用自行捕获破坏流程一致性Generator 底座不替代 qiankun、Module Federation 或 import-map,而是增强其加载阶段的可控性:
loadMicroApp 前,先运行对应 Generator 获取资源清单和加载策略,再交由框架原生机制加载,实现“策略前置,加载后置”ModuleFederationPlugin,Generator 可动态生成 remote 配置(如根据用户 region 切换 CDN 域名),yield 出配置对象供 runtime 使用import(...) 动态导入,Generator 的 yield 可返回带条件的 import 表达式字符串(如 yield `./apps/${env}/app-a.mjs`),由调度器安全求值并加载Generator 在此处的价值不在语法糖,而在执行语义的显式化:
立即学习“前端免费学习笔记(深入)”;
next() 调用必须携带上下文参数(如 next({ network: '4g', userRole: 'admin' })),供 yield 内部逻辑做决策,这是回调或 async/await 难以自然表达的双向通信return() 终止未完成的 yield 链,清理定时器、abort controller 和事件监听器next(value)
Symbol.asyncIterator 扩展 Generator,支持 for await...of 消费异步加载流,用于渐进式渲染或流式组件注入