客户端设置指南¶
使用适用于你平台的渲染器将 A2UI 集成到你的应用程序中。
渲染器¶
| 渲染器 | 平台 | 状态 |
|---|---|---|
| Lit (Web Components) | Web | ✅ 稳定 |
| Angular | Web | ✅ 稳定 |
| Flutter (GenUI SDK) | 移动端/桌面端/Web | ✅ 稳定 |
| React | Web | 🚧 2026 年第一季度发布 |
| SwiftUI | iOS/macOS | 🚧 计划于 2026 年第二季度 |
| Jetpack Compose | Android | 🚧 计划于 2026 年第二季度 |
Web Components (Lit)¶
注意
Lit 客户端库尚未发布到 NPM。请在接下来的几天内回来查看。
Lit 渲染器使用:
- Message Processor: 管理 A2UI 状态并处理传入消息
<a2ui-surface>component: 在你的应用中渲染界面- Lit Signals: 为自动 UI 更新提供响应式状态管理
TODO: 添加经过验证的设置示例。
查看工作示例: Lit shell 示例
Angular¶
注意
Angular 客户端库尚未发布到 NPM。请在接下来的几天内回来查看。
Angular 渲染器提供:
provideA2UI()function: 在你的应用配置中配置 A2UISurfacecomponent: 渲染 A2UI 界面MessageProcessorservice: 处理传入的 A2UI 消息
TODO: 添加经过验证的设置示例。
查看工作示例: Angular 餐厅示例
Flutter (GenUI SDK)¶
Flutter 使用 GenUI SDK,它提供原生 A2UI 渲染。
文档: GenUI SDK | GitHub | GenUI Flutter 包中的 README
连接到代理¶
你的客户端应用程序需要: 1. 从代理 接收 A2UI 消息(通过传输层) 2. 使用 Message Processor 处理消息 3. 将 用户操作发送 回代理
常见的传输选项: - Server-Sent Events (SSE): 从服务器到客户端的单向流式传输 - WebSockets: 双向实时通信 - A2A 协议: 支持 A2UI 的标准化代理对代理通信
TODO: 添加传输实现示例。
参见: 传输层指南
处理用户操作¶
当用户与 A2UI 组件交互(点击按钮、提交表单等)时,客户端: 1. 从组件捕获操作事件 2. 解析操作所需的任何数据上下文 3. 将操作发送给代理 4. 处理代理的响应消息
TODO: 添加操作处理示例。
错误处理¶
需要处理的常见错误:
- 无效的界面 ID (Invalid Surface ID): 在收到 beginRendering 之前引用了界面
- 无效的组件 ID (Invalid Component ID): 组件 ID 在界面内必须唯一
- 无效的数据路径 (Invalid Data Path): 检查数据模型结构和 JSON Pointer 语法
- 模式验证失败 (Schema Validation Failed): 验证消息格式是否符合 A2UI 规范
TODO: 添加错误处理示例。