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动图录制

参考资料

相关推荐
幸运小圣几秒前
全面解析 Web 核心性能指标:LCP、INP、CLS 是什么、怎么用、怎么看
前端
如果超人不会飞5 分钟前
TinyRobot SuggestionPopover智能建议弹出框组件
前端·vue.js
ShyanZh10 分钟前
【skill】Humanizer-zh:24条规则消灭AI写作痕迹
人工智能·ai写作·skill
电商软件开发 小银13 分钟前
思域不再安全?AI+独立APP破局指南
人工智能·软件开发·数字化转型·商业模式·超级app·商业思维·ai 矩阵运营
asyxchenchong88818 分钟前
最新Hermes Agent 技能封装与科研自动化:以 Meta-Analysis 为例-实现从文献检索到绘图的一站式工作流
运维·人工智能·自动化
武子康20 分钟前
调查研究-168 MiroFish 本地化部署分析:主仓库、Zep Cloud、离线 Fork 与真正可控的多智能体沙盘
人工智能·aigc·openai
LiuJun2Son20 分钟前
Angular 快速入门:从零搭建你的第一个应用
前端·javascript·angular.js
烬羽20 分钟前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构
诗词在线25 分钟前
求推荐飞花令
大数据·人工智能·python
云烟成雨TD28 分钟前
Spring AI 1.x 系列【47】 MCP Annotations 模块
java·人工智能·spring