
教程
1. 定义和配置 UI 组件
首先,创建您的第一个 UI 组件。对于每个组件,您需要提供一个唯一的标识符,该标识符将用于在您的图代码中引用该组件。src/agent/ui.tsx
langgraph.json 配置中定义您的 UI 组件
ui 部分指向图将使用的 UI 组件。默认情况下,我们建议使用与图名称相同的键,但您可以根据需要拆分组件,有关更多详细信息,请参阅自定义 UI 组件的命名空间。 LangSmith 将自动捆绑您的 UI 组件代码和样式,并将其作为外部资产提供,这些资产可以由 LoadExternalComponent 组件加载。一些依赖项,例如 react 和 react-dom,将自动从捆绑中排除。 CSS 和 Tailwind 4.x 也开箱即用,因此您可以在 UI 组件中自由使用 Tailwind 类以及 shadcn/ui。- src/agent/ui.tsx
- src/agent/styles.css
2. 在您的图中发送 UI 组件
- Python
- JS
src/agent.py
3. 在您的 React 应用程序中处理 UI 元素
在客户端,您可以使用useStream() 和 LoadExternalComponent 来显示 UI 元素。
src/app/page.tsx
LoadExternalComponent 将从 LangSmith 获取 UI 组件的 JS 和 CSS,并在影子 DOM 中渲染它们,从而确保与应用程序其余部分的样式隔离。
操作指南
在客户端提供自定义组件
如果您的客户端应用程序中已加载组件,您可以提供这些组件的映射,以便直接渲染,而无需从 LangSmith 获取 UI 代码。组件加载时显示加载 UI
您可以提供一个备用 UI,在组件加载时渲染。自定义 UI 组件的命名空间。
默认情况下,LoadExternalComponent 将使用 useStream() hook 中的 assistantId 来获取 UI 组件的代码。您可以通过向 LoadExternalComponent 组件提供 namespace prop 来对其进行自定义。
- src/app/page.tsx
- langgraph.json
从 UI 组件访问和与线程状态交互
您可以使用useStreamContext hook 访问 UI 组件内的线程状态。
将额外上下文传递给客户端组件
您可以通过向LoadExternalComponent 组件提供 meta prop 来向客户端组件传递额外的上下文。
useStreamContext hook 在 UI 组件中访问 meta prop。
从服务器流式传输 UI 消息
您可以使用useStream() hook 的 onCustomEvent 回调在节点执行完成之前流式传输 UI 消息。当 LLM 正在生成响应时更新 UI 组件时,这尤其有用。
ui.push() / push_ui_message() 来推送更新到 UI 组件。
- Python
- JS
- ui.tsx
从状态中移除 UI 消息
与通过附加 RemoveMessage 从状态中移除消息类似,您可以通过使用 UI 消息的 ID 调用remove_ui_message / ui.delete 从状态中移除 UI 消息。
- Python
- JS
了解更多
以编程方式连接这些文档到 Claude、VSCode 等,通过 MCP 获取实时答案。