useExternalStoreRuntime 适配器连接到 useStream。
工作原理
- 使用
useStream进行流式处理 — 连接到你的智能体,获取响应式消息、加载状态以及提交/取消回调 - 使用
useExternalStoreRuntime适配 — 将stream.messages桥接到 assistant-ui 的运行时格式,将BaseMessage[]转换为ThreadMessageLike[] - 提供运行时 — 用
AssistantRuntimeProvider包装你的 UI,并渲染任何 assistant-ui 的线程组件
安装
连接 useStream
useExternalStoreRuntime 适配器将 stream.messages 桥接到 assistant-ui 运行时。将其传递给 AssistantRuntimeProvider 并渲染任何线程组件:
转换消息
toThreadMessages 将 LangChain 的 BaseMessage[] 映射为 assistant-ui 期望的 ThreadMessageLike[] 格式。处理每种消息类型——人类、AI 和工具——并转换内容块、工具调用和推理令牌:
自定义线程 UI
<Thread /> 提供了一个完整的默认线程 UI,包括消息列表、输入框和滚动管理。通过覆盖组件插槽来自定义各个部分:
最佳实践
- 记忆化消息转换: 将
toThreadMessages(stream.messages)包装在useMemo中,避免在每次渲染时重新运行转换 - 处理附件: 使用
CompositeAttachmentAdapter配合SimpleImageAttachmentAdapter处理图片上传;通过自定义适配器扩展以支持文件 - 使用分支: assistant-ui 通过
MessageBranch内置了消息分支支持;编辑消息可以从该点重新生成 - 线程持久化: 使用
useStream并设置fetchStateHistory: true和reconnectOnMount: true,让 assistant-ui 在页面加载时能够访问完整的线程历史
Connect these docs to Claude, VSCode, and more via MCP for real-time answers.

