18行代码,纯前端实现ChatGPT聊天机器人

大家好,我是创业时长五年半的张总,喜欢唱、跳、rap、篮球。

最近一年我做了几款AI产品,主要是SD绘画AI Chat类产品,所以对于各类AI产品开发略有些心得。接下来我会分享如何从0到1开发各种各样的AI产品,以及关于技术、产品、和运营的一些见解。

本文是 《开发ChatGPT聊天机器人的100种姿势》 系列文章的第一篇,我会用N种方式教你从一个简单对话框写到一个完整的应用,每个姿势都力求舒服。

最简AI聊天机器人

千里之行,始于足下

先freestyle一个最简18行代码的ChatGPT聊天机器人。

使用纯HTML、JavaScript实现,不使用任何第三方库。打开网页后会发送"你好"给ChatGPT,ChatGPT收到后会在控制台输出响应的结果。

html 复制代码
<html>
<head>
  <script>
    const headers = new Headers();
    headers.append("Content-Type", "application/json");
    headers.append("Authorization", "Bearer sk-UgtZ6M4qw7Ycfzok0cC1E8C690A04b92B38e381c4c5661D5");
    const body = JSON.stringify({
      model: "gpt-3.5-turbo",
      messages: [{ role: "user", content: "你好" }],
    });
    const requestOptions = { method: 'POST', headers, body };
    fetch("https://ai98.vip/v1/chat/completions", requestOptions)
      .then(response => response.text())
      .then(result => console.log(result))
      .catch(error => console.log('error', error));
  </script>
</head>
</html>

实操

  1. 复制上面的代码,保存为index.html,双击运行
  2. 打开浏览器控制台,如果能看到下面的数据,那么恭喜你,你的第一个AI应用就写好了!

如果报错,去控制台看问题,比如apiKey失效(key是有额度限制的,具体看"注意"事项)

知识要点

  • 设置HTTP请求中header的Authorization属性,这是请求API的秘钥。扩展知识JWT
  • 使用原生Fetch API作为请求方法
  • 调用OpenAI API ,model是请求的模型,messages是消息列表,其中role是消息的角色(system、user、assistant等),content是内容,本文代码中是user角色,表示是用户发送的消息 ``

注意:

  • 因为一些原因,OpenAI官方的API可能无法访问,所以,代码中我使用了代理地址
  • 代码中的sk-xxxx是访问API的key,key是真实的,我免费开放了$10的额度,用完可以再问我要

下期预告

  • 📝 支持连续对话功能,具备上下文记忆

  • 📜 支持Stream流式对话(打字机效果)

  • 🌀 新增加载中的css动效

效果预览:

Sige

文章有写的不好的地方,欢迎指正。

前几期可能没有一些"炫酷"的代码和界面,主打一个简洁、高效,快速上手。

系列代码可以在Github仓库中查看:GitHub - miaoihan/100way-to-build-ai: 开发AI应用的100种姿势

本文用到的工具

vscode、Chrome、Mac自带截图工具、GIF Brewery 3动图录制

参考资料

相关推荐
玩电脑的辣条哥2 小时前
Python如何播放本地音乐并在web页面播放
开发语言·前端·python
taoqick2 小时前
对PosWiseFFN的改进: MoE、PKM、UltraMem
人工智能·pytorch·深度学习
ew452182 小时前
ElementUI表格表头自定义添加checkbox,点击选中样式不生效
前端·javascript·elementui
suibian52352 小时前
AI时代:前端开发的职业发展路径拓宽
前端·人工智能
画月的亮2 小时前
element-ui 使用过程中遇到的一些问题及解决方法
javascript·vue.js·ui
Moon.92 小时前
el-table的hasChildren不生效?子级没数据还显示箭头号?树形数据无法展开和收缩
前端·vue.js·html
m0_526119402 小时前
点击el-dialog弹框跳到其他页面浏览器的滚动条消失了多了 el-popup-parent--hidden
javascript·vue.js·elementui
垚垚 Securify 前沿站2 小时前
深入了解 AppScan 工具的使用:筑牢 Web 应用安全防线
运维·前端·网络·安全·web安全·系统安全
预测模型的开发与应用研究3 小时前
数据分析的AI+流程(个人经验)
人工智能·数据挖掘·数据分析
源大模型3 小时前
OS-Genesis:基于逆向任务合成的 GUI 代理轨迹自动化生成
人工智能·gpt·智能体