Ant Design X - React Component Library for Building AI Chat Applications
data:image/s3,"s3://crabby-images/49e7e/49e7e96fe1847e6c7e1030520babdee5000eec35" alt="Cover image for Ant Design X - React Component Library for Building AI Chat Applications"
Introduction
Ant Design X
is a React component library focused on building AI-driven user interfaces. It provides a complete solution to help developers quickly build professional AI interaction interfaces.
Core Features
- 🌈 Best Practices from Enterprise AI Products: Based on RICH interaction paradigm, providing excellent AI interaction experience
- 🧩 Flexible Atomic Components: Covering most AI conversation scenarios, helping to quickly build personalized AI interaction pages
- ⚡ Out-of-the-box Model Integration: Easy integration with OpenAI-standard model inference services
- 🔄 Efficient Conversation Data Flow Management: Providing useful data flow management features for more efficient development
- 📦 Rich Template Support: Providing multiple templates to quickly start LUI application development
- 🛡 Full TypeScript Coverage: Developed with TypeScript, providing complete type support
- 🎨 Deep Theme Customization: Supporting fine-grained style adjustments to meet various scenario needs
Installation
NPM Installation
# Using npm
npm install @ant-design/x --save
# Using yarn
yarn add @ant-design/x
# Using pnpm
pnpm add @ant-design/x
Browser Import
You can also directly include the files using script and link tags, and use the global variable antdx
:
<script src="https://unpkg.com/@ant-design/x/dist/antdx.min.js"></script>
Note: Using pre-built files is strongly discouraged as it prevents tree-shaking and makes it difficult to receive quick bug fixes for underlying dependency modules.
Important:
antdx.js
andantdx.min.js
depend onreact
,react-dom
, anddayjs
. Please ensure these files are included beforehand.
Basic Usage Examples
1. Simple Chat Interface
import React from 'react';
import { Bubble, Sender } from '@ant-design/x';
const ChatDemo = () => {
const messages = [
{
content: 'Hello, Ant Design X!',
role: 'user',
}
];
return (
<div>
<Bubble.List items={messages} />
<Sender />
</div>
);
};
2. Model Service Integration
import { useXAgent, XRequest } from '@ant-design/x';
const { create } = XRequest({
baseURL: 'https://api.openai.com/v1',
dangerouslyApiKey: process.env['OPENAI_API_KEY'],
model: 'gpt-4',
});
const AIComponent = () => {
const [agent] = useXAgent({
request: async (info, callbacks) => {
const { message } = info;
const { onUpdate } = callbacks;
try {
create(
{
messages: [{ role: 'user', content: message }],
stream: true,
},
{
onUpdate: (chunk) => {
const content = JSON.parse(chunk.data).choices[0].delta.content;
onUpdate(content);
},
},
);
} catch (error) {
console.error(error);
}
},
});
return <Sender onSubmit={(msg) => agent.request({ message: msg })} />;
};
3. Complete Conversation Management
import { useXAgent, useXChat, Bubble, Sender } from '@ant-design/x';
const ChatApp = () => {
const [agent] = useXAgent({
request: async (info, callbacks) => {
// Implement conversation request logic
},
});
const { messages, onRequest } = useXChat({ agent });
const items = messages.map(({ message, id }) => ({
key: id,
content: message,
}));
return (
<div>
<Bubble.List items={items} />
<Sender onSubmit={onRequest} />
</div>
);
};
Tree Shaking
Ant Design X supports ES modules-based tree shaking by default, meaning you can import only the components you need, and unused component code won’t be bundled into your application:
import { Bubble } from '@ant-design/x'; // Only import the Bubble component
TypeScript Support
Ant Design X is written in TypeScript and provides complete type definition files. For the best development experience, it’s recommended to use TypeScript:
import type { BubbleProps } from '@ant-design/x';
const MyComponent: React.FC<BubbleProps> = (props) => {
// ...
};
Best Practices
- Import Components as Needed: Avoid importing everything to reduce bundle size
- Use TypeScript: Get better type hints and development experience
- Properly Manage API Keys: Don’t expose sensitive information in the frontend
- Implement Error Handling: Properly handle potential AI service exceptions
- Optimize User Experience: Use loading states and feedback mechanisms appropriately
Summary
Ant Design X provides a one-stop solution for building AI-driven user interfaces. Through its rich components and convenient development experience, developers can quickly build professional AI chat applications. With continuous updates and improvements, it will play an increasingly important role in advancing intelligent interaction development.
More Articles
![OpenAI 12-Day Technical Livestream Highlights Detailed Report [December 2024]](/_astro/openai-12day.C2KzT-7l_1ndTgg.jpg)
data:image/s3,"s3://crabby-images/c1bf5/c1bf5865286d00ab4d17bfbd91f2ce0a455a13a8" alt="AI Model Tools Comparison How to Choose Between SGLang, Ollama, VLLM, and LLaMA.cpp?"
data:image/s3,"s3://crabby-images/a4ba7/a4ba7c68c21d4134a0e14972d54e27dae70d4913" alt="CES 2024 Review:Revisiting the Tech Highlights of 2024"
data:image/s3,"s3://crabby-images/61b97/61b970a4a7550922b5a124c43e3ee9497f307957" alt="VLC Automatic Subtitles and Translation (Based on Local Offline Open-Source AI Models) | CES 2025"
data:image/s3,"s3://crabby-images/37926/37926da66646b6654210b1c1a3480ccfc02878f9" alt="ClearerVoice-Studio: A One-Stop Solution for Speech Enhancement, Speech Denoising, Speech Separation and Speaker Extraction"
data:image/s3,"s3://crabby-images/ae5fe/ae5fe3499027252db14d2a4582a86100a22c4f39" alt="CogAgent-9B Released: A GUI Interaction Model Jointly Developed by Zhipu AI and Tsinghua"
data:image/s3,"s3://crabby-images/30358/303582cbd83d7ea7faaaa213711feae8f4958f41" alt="How to Install and Use ComfyUI on Windows - Complete Guide"
data:image/s3,"s3://crabby-images/9b527/9b52774d783754cb309b77477f9a28ccd479cab5" alt="DeepSeek-V3 Model In-Depth Analysis: A Brilliant Star in the New AI Era"
data:image/s3,"s3://crabby-images/e82dd/e82ddb4377d3a1992ca7d1d67b2085e5377d0252" alt="DeepSeek R1:How Reinforcement Learning Reshapes Language Model Reasoning?"
Related Posts
No related posts yet