🧳 我的 React Trip 之旅(5):我的 AI 聊天机器人,今天又把用户气笑了

从 DeepSeek 到 Kimi,我写了个"模型切换器",结果发现 AI 也会胡说八道


🤖 开头:用户问"附近有什么好玩的?",AI 回"建议去火星"

集成 LLM 时,我以为只要调个 API 就行。结果第一次测试,用户问旅游建议,AI 回:"推荐您乘坐 SpaceX 前往火星,门票仅需 2 亿美元。"

我差点把电脑砸了。

后来才明白:不同模型,性格不同。DeepSeek 严谨,Kimi 活泼,Doubao 像个段子手。

于是,我决定------不绑死一个模型,做个"AI 模型切换器"


🔌 核心思想:抽象出一个 chat(model, messages) 函数

不管外面风多大,我的组件只认一个接口:

javascript 复制代码
// llm/chat.js
export async function chat(model, messages) {
  const apiKey = getApiKey(model); // 从 .env 读取
  const url = getModelEndpoint(model);

  const response = await fetch(url, {
    method: 'POST',
    headers: { 'Authorization': `Bearer ${apiKey}`, 'Content-Type': 'application/json' },
    body: JSON.stringify({ messages, stream: true })
  });

  if (!response.ok) throw new Error('LLM request failed');

  return response; // 支持流式读取
}

✅ 组件调用:const res = await chat('kimi', messages);

✅ 换模型?只需改第一个参数,业务代码一行不动


💬 流式输出:让用户看到 AI "打字"的过程

普通请求是"等半天,啪一下全出来"。但聊天要有对话感

我用 ReadableStream 逐字解析:

ini 复制代码
const reader = response.body.getReader();
while (true) {
  const { done, value } = await reader.read();
  if (done) break;
  const chunk = new TextDecoder().decode(value);
  // 解析 chunk 中的 content,追加到 messages
  setMessages(prev => [...prev.slice(0, -1), { role: 'assistant', content: newContent }]);
}

用户看到文字一个一个蹦出来,感觉 AI 在认真思考,而不是复制粘贴。


🧠 上下文管理:别让 AI 忘记刚才聊了啥

用户问:"推荐海岛",AI 回:"马尔代夫"。

用户接着问:"那里签证难吗?",AI 却回:"您说的是哪个地方?"

------因为它没收到上下文!

我在 Zustand 里维护完整对话历史,并用 LRU 缓存 控制长度(避免 token 超限):

ini 复制代码
// stores/useChatStore.js
const MAX_MESSAGES = 10;
const addMessage = (msg) => {
  const newMsgs = [...get().messages, msg].slice(-MAX_MESSAGES);
  set({ messages: newMsgs });
};

😅 结尾:AI 还是会犯傻,但至少我能快速换一个

现在,如果 Kimi 又开始胡说八道,我只需在代码里改一行:

csharp 复制代码
// 从 'kimi' 换成 'deepseek-r1'
const res = await chat('deepseek-r1', messages);

用户毫无感知,但 AI 突然变得一本正经。

前端智能,不是让 AI 完美,而是让切换成本趋近于零

下一站,我要解决一个看似简单却坑哭无数人的问题------如何全局弹出一个 Toast?UI 库不够用,我只好自己造了个"会飞的通知"

相关推荐
boombb1 小时前
数据驱动与CSS预定义样式:实现灵活多变的Banner布局
前端
JIngJaneIL1 小时前
基于Java失物招领系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·vue
鼎道开发者联盟1 小时前
当界面会思考:AIGUI八要素驱动DingOS实现“感知-生成-进化“闭环
前端·人工智能·ai·gui
豐儀麟阁贵1 小时前
9.3获取字符串信息
java·开发语言·前端·算法
苦夏木禾1 小时前
使用css制作一个环形进度展示圈
前端·css
by__csdn1 小时前
ES6新特性全攻略:JavaScript的现代革命
开发语言·前端·javascript·typescript·ecmascript·es6·js
by__csdn1 小时前
Vue 双向数据绑定深度解析:从原理到实践的全方位指南
前端·javascript·vue.js·typescript·前端框架·vue·ecmascript
奋斗吧程序媛1 小时前
前端 Token 管理与最佳实践
前端·vue.js
linhuai1 小时前
在flutter中dio应该如何封装和使用
前端