【前端】自己从头实现一个gpt聊天页面
预览

最小化功能点
- 主界面:侧边栏会话历史、聊天窗口发送和断开。
- 侧边栏:展示会话列表,每个会话包含多条聊天记录, 通过localstorage本地储存和恢复,会话需要重命名和删除。
- 聊天框:区分一下发送者和回答者的布局(对于代码可以加入高亮功能)。
- 流式请求对接:通过fetch读取text/oct-stream格式的请求。
- 历史记录:折叠gpt的回答, 点击展开可弹框查看全部内容, 防止页面卡顿。
gpt总结的步骤
制作一个 ChatGPT 界面涉及多个功能点和步骤,以下是一个简要的总结,涵盖了前端和后端的基本构建要求。1. 基本功能点
a. 用户输入
输入框:用户可以在文本框中输入问题或消息。
提交按钮:点击按钮提交输入,或实现键盘快捷键(例如回车键)。
b. 显示对话
消息显示区:用于展示用户和 ChatGPT 的对话内容。
滚动效果:确保聊天框可以自动滚动,显示最新消息。
c. 响应生成
ChatGPT 交互:根据用户输入,通过后端调用 OpenAI API 或类似的 AI 服务来生成回应。
异步显示:响应从 API 获取后实时更新,支持流式响应。
d. 输入和响应格式
文本和富文本:支持文本消息和可能的富文本(例如图片、链接等)。
加载指示器:当 AI 正在处理请求时,显示加载动画或提示。
e. 断开/停止功能
停止按钮:允许用户停止流式响应,关闭连接。
2. 功能细节实现步骤
a. 前端开发
UI 设计:设计清晰简洁的用户界面,包括输入框、聊天历史显示区域、发送按钮、加载指示器等。
输入框及事件监听:实现输入框,监听 enter 键或发送按钮的点击事件,将用户输入发送到后端。
显示聊天历史:使用滚动条或自动滚动功能显示聊天记录,确保对话内容实时更新。
异步请求与响应显示:通过 fetch 或 WebSocket 与后端交互,接收并显示生成的回答。
加载指示器:当请求正在处理中,显示加载指示器(例如转圈或 “typing...”)。
b. 后端开发
API 请求处理:实现一个处理前端请求的接口,接收用户消息并传递给 AI 服务。
OpenAI API 或其他聊天引擎:使用 OpenAI 的 API 或自定义 AI 模型生成响应。需要处理 API 密钥和认证。
流式响应:支持长时间的流式响应,利用 ReadableStream、WebSocket 或 Server-Sent Events (SSE) 实现实时响应。
消息缓存和处理:存储聊天历史,确保会话状态得以保留。可能需要简单的缓存机制。
断开和中断请求:实现 API 连接的中断功能(例如使用 AbortController 取消正在进行的请求),以支持停止和断开流式响应。
c. 流式响应与断开连接
前端:通过 fetch 与流数据接口交互,逐步显示响应内容。
后端:实现流式 API 响应,处理客户端请求并逐步推送数据。支持连接中断。
断开连接:通过前端按钮或事件监听来停止流式请求。确保前后端能够优雅地断开连接(例如通过 AbortController 或 WebSocket 的 close() 方法)。
3. 进阶功能(可选)
a. 身份认证和权限管理
用户身份认证:如果需要,可以添加用户身份验证功能(如 OAuth、JWT 等)。
权限控制:根据用户角色控制访问不同功能。
b. 消息翻译
语言切换:支持多语言输入和输出,自动或手动切换对话语言。
翻译功能:在不同语言环境下,自动翻译用户输入和 AI 的回应。
c. 聊天存档
历史记录:实现会话历史的保存,用户可以查看过去的聊天记录。
导出功能:提供导出聊天记录的选项(如文本文件、PDF 等)。
d. UI/UX优化
自定义主题:支持不同的主题切换(如浅色/深色模式)。
语音输入与输出:实现语音识别和语音合成功能,提升用户体验。
聊天气泡样式:美化聊天框,增强交互感。
4. 技术栈选择
a. 前端技术
HTML/CSS:用于布局和样式,确保界面简洁美观。
JavaScript/TypeScript:前端逻辑,处理用户输入、与后端交互、展示响应。
React/Vue/Angular:现代前端框架,用于构建高效的交互式应用。
WebSocket 或 Server-Sent Events (SSE):用于实时双向通信。
b. 后端技术
Node.js + Express/Koa:用于处理 HTTP 请求,管理与 AI 服务的交互。
Python + Flask/Django:如果使用 Python 提供 AI 服务,可以选择 Flask 或 Django。
OpenAI API:与 OpenAI 的 GPT 接口交互,生成响应。
c. 其他工具
Redis:用于存储用户会话历史和缓存数据。
数据库:例如 MySQL、PostgreSQL 或 MongoDB,用于存储用户信息和聊天记录。
总结
用户界面设计:包含消息显示区、输入框、按钮和加载提示。
与后端交互:通过异步请求与 AI 服务交互,支持流式响应。
消息显示和流式响应:实时显示消息并更新 UI,支持停止和断开流式响应。
断开功能:优雅地处理连接的断开和请求的取消。
通过以上功能点和步骤,你可以实现一个基本的 ChatGPT 界面,并在此基础上进行扩展和优化。
相关文章:
【前端】自己从头实现一个gpt聊天页面
预览 最小化功能点 主界面:侧边栏会话历史、聊天窗口发送和断开。侧边栏:展示会话列表,每个会话包含多条聊天记录, 通过localstorage本地储存和恢复,会话需要重命名和删除。聊天框:区分一下发送者和回答者…...
数据结构——二叉树(2025.2.12)
目录 一、树 1.定义 (1)树的构成 (2)度 2.二叉树 (1)定义 (2)二叉树的遍历 (3)遍历特性 二、练习 1.二叉树 (1)创建二叉树…...
Vulhub靶机 ActiveMQ任意 文件写入(CVE-2016-3088)(渗透测试详解)
一、开启vulhub环境 docker-compose up -d 启动 docker ps 查看开放的端口 漏洞版本:ActiveMQ在5.14.0之前的版本(不包括5.14.0) 二、访问靶机IP 8161端口 默认账户密码都是admin 1、利用bp抓包,修改为PUT方法并在fileserver…...
跟着李沐老师学习深度学习(十一)
经典的卷积神经网络 在本次笔记中主要介绍一些经典的卷积神经网络模型,主要包含以下: LeNet:最早发布的卷积神经网络之一,目的是识别图像中的手写数字;AlexNet: 是第一个在大规模视觉竞赛中击败传统计算机…...
【微软- Entra ID】Microsoft Entra ID
Microsoft Entra ID是微软提供的基于云的身份和访问管理服务。Microsoft Entra ID是一个全面的解决方案,用于管理身份、执行访问策略以及在云和本地保护您的应用程序和数据。 目录 一、查看 Microsoft Entra ID 微软Entra租户 微软Entra模式 二、比较Microsoft Entra ID与…...
Halcon相机标定
1,前言。 相机的成像过程实质上是坐标系的转换。首先空间中的点由“世界坐标系”转换到“相机坐标系”,然后再将其投影到成像平面(图像物理坐标系),最后再将成像的平面上的数据转换为图像像素坐标系。但是由于透镜的制…...
Linux 配置 MySQL 定时自动备份到另一台服务器
Linux 配置 MySQL 定时自动备份到另一台服务器 前言1、配置服务器通信1.1:配置过程 2、编写自动备份sh脚本文件3:设置定时自动执行 前言 此方案可使一台服务器上的 MySQL 中的所有数据库每天 0 点自动转储为 .sql 文件,然后将文件同步到另一…...
《安富莱嵌入式周报》第350期:Google开源Pebble智能手表,开源模块化机器人平台,开源万用表,支持10GHz HRTIM的单片机,开源CNC控制器
周报汇总地址:嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 视频版: https://www.bilibili.com/video/BV1YPKEeyEeM/ 《安富莱嵌入式周报》第350期:Google开…...
LabVIEW与小众设备集成
在LabVIEW开发中,当面临控制如布鲁克OPUS红外光谱仪这类小众专业设备的需求,而厂家虽然提供了配套软件,但由于系统中还需要控制其他设备且不能使用厂商的软件时,必须依赖特定方法通过LabVIEW实现设备的控制。开发过程中࿰…...
无人机之无线传输技术!
一、Lightbridge和OcuSync图传技术 Lightbridge技术:这是大疆自主研发的一种专用通信链路技术,使用单向图像数据传输,类似于电视广播塔的数据传输形式。它主要采用2.4GHz频段进行传输,并且可以实现几乎“零延时”的720p高清图像传…...
移远通信边缘计算模组成功运行DeepSeek模型,以领先的工程能力加速端侧AI落地
近日,国产大模型DeepSeek凭借其“开源开放、高效推理、端侧友好”的核心优势,迅速风靡全球。移远通信基于边缘计算模组SG885G,已成功实现DeepSeek模型的稳定运行,并完成了针对性微调。 目前,该模型正在多款智能终端上进…...
rust学习一、入门之搭建简单开发环境
1、搭建开发环境(windows11) a.登录官网 一看就明白,此处略。 b.安装rustup 一看就明白,此处略。 c.安装 cargo script 或者 rust-script script cargo install cargo-script 完成后 注意:时间有一点点久。 测试 cargo s…...
FANUC机器人示教器中如何显示或关闭寄存器或IO的注释信息?
FANUC机器人示教器中如何显示或关闭寄存器或IO的注释信息? 如下图所示,我们打开一个子程序,可以看到程序中的寄存器和IO是显示注释信息的, 如果想关闭注释显示的话,怎么设置? 如下图所示,按下下一页的箭头(NEXT键), 如下图所示,点击“编辑”,在弹出的窗口中,选择“…...
在SpringBoot项目中有k8s配置,但报错
如下报错一般是你没有将k8s的config拷贝到项目里,你可以将k8s主节点的config拷贝一下到项目中。 2025-02-13 09:27:21.873 ERROR 1671 --- [.models.V1Pod-1] i.k.c.informer.cache.ReflectorRunnable : class io.kubernetes.client.openapi.models.V1Pod#Reflec…...
在springboot加vue项目中加入图形验证码
后端 首先先要创建一个CaptchaController的类,可以在下面的代码中看到 在getCaptcha的方法里面写好了生成随机的4位小写字母或数字的验证码,然后通过BufferedImage类变为图片,顺便加上了干扰线。之后把图片转为Base64编码方便传给前端 为了…...
23. AI-大语言模型
文章目录 前言一、LLM1. 简介2. 工作原理和结构3. 应用场景4. 最新研究进展5. 比较 二、Transformer架构1. 简介2. 基本原理和结构3. 应用场景4. 最新进展 三、开源1. 开源概念2. 开源模式3. 模型权重 四、再谈DeepSeek 前言 AI 一、LLM LLM(Large Language Mod…...
蓝桥杯备赛笔记(二)
这里的笔记是关于蓝桥杯关键知识点的记录,有别于基础语法,很多内容只要求会用就行,无需深入掌握。 文章目录 前言一、时间复杂度1.1 时间复杂度⭐1.2 空间复杂度1.3 分析技巧 二、枚举2.1 枚举算法介绍2.2 解空间的类型2.3 循环枚举解空间 三…...
MATLAB中的APPdesigner绘制多图问题解析?与逻辑值转成十进制
在matlab APPdesigner中绘图可以用UIAxes组件进行绘图,但是当想多张图时,只能提前绘制图像区域不方便。下面是几种办法: 为了操作可以添加Panl组件,方便操作。 1、当是要求的几个图像大小都是相同时刻采用函数: til…...
Spring Cloud-Sentinel
Sentinel服务熔断与限流 Sentinel 是面向分布式、多语言异构化服务架构的流量治理组件,主要以流量为切入点,从流量控制、流量路由、熔断降级、系统自适应保护等多个维度来帮助用户保障微服务的稳定性。 官网地址:home | Sentinelhttps://sen…...
Java中使用EasyExcel
Java中使用EasyExcel 文章目录 Java中使用EasyExcel一:EasyExcel介绍1.1、核心函数导入数据导出数据 1.2、项目实际应用导入数据导出数据 1.3、相关注解ExcelProperty作用示例 二:EasyExcel使用2.1、导入功能2.2、导出功能 三:EasyExcel完整代…...
Linux中退出vi编辑器的命令
在Linux中退出vi编辑器的命令有以下几种: 保存并退出:在命令模式下,按下Esc键退出插入模式,然后输入:wq或:x,按下回车键即可保存修改并退出vi编辑器。 不保存退出:在命令模式下,按…...
建筑兔零基础自学python记录18|实战人脸识别项目——视频检测07
本次要学视频检测,我们先回顾一下图片的人脸检测建筑兔零基础自学python记录16|实战人脸识别项目——人脸检测05-CSDN博客 我们先把上文中代码复制出来,保留红框的部分。 然后我们来看一下源代码: import cv2 as cvdef face_detect_demo(…...
自定义基座实时采集uniapp日志
自定义基座实时采集uniapp日志 打测试包给远端现场(测试/客户)实际测试时也能实时看到日志了,也有代码行数显示。 流程设计 #mermaid-svg-1I5W9r1DU4xUsaTF {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid…...
【java】方法:遍历/求最大值/判断是否存在
1.遍历 public class ArrayTraversal {// 定义一个静态方法用于遍历数组并在一行上显示元素public static void printArray(int[] arr) {for (int num:arr) {// 打印数组元素,不换行System.out.print(num" ");}// 遍历结束后换行System.out.println();}p…...
【ISO 14229-1:2023 UDS诊断全量测试用例清单系列:第六节】
ISO 14229-1:2023 UDS诊断服务测试用例全解析(ReadDataByIdentifier0x22服务) 作者:车端域控测试工程师 发布日期:2025年2月13日 关键词:UDS诊断协议、0x22服务、ReadDataByIdentifier、DID读取、ECU测试 一、服务功能…...
dedecms 开放重定向漏洞(附脚本)(CVE-2024-57241)
免责申明: 本文所描述的漏洞及其复现步骤仅供网络安全研究与教育目的使用。任何人不得将本文提供的信息用于非法目的或未经授权的系统测试。作者不对任何由于使用本文信息而导致的直接或间接损害承担责任。如涉及侵权,请及时与我们联系,我们将尽快处理并删除相关内容。 0x0…...
AI知识库 - Cherry Studio
1 引言: 最近 DeepSeek 很火啊,想必大家都知道,DeepSeek 这个开源的模型出来后,因其高质量能力和R1 的思维链引发了大家本地部署的热潮。我也不例外,本地部署了一个 14B 的模型,然后把,感觉傻傻…...
20250213 隨筆 雪花算法
雪花算法(Snowflake Algorithm) 雪花算法(Snowflake) 是 Twitter 在 2010 年開發的一種 分布式唯一 ID 生成算法,它可以在 高併發場景下快速生成全局唯一的 64-bit 長整型 ID,且不依賴資料庫,具…...
(前端基础)HTML(一)
前提 W3C:World Wide Web Consortium(万维网联盟) Web技术领域最权威和具有影响力的国际中立性技术标准机构 其中标准包括:机构化标准语言(HTML、XML) 表现标准语言(CSS) 行为标准…...
pdf.js默认显示侧边栏和默认手形工具
文章目录 默认显示侧边栏(切换侧栏)默认手形工具(手型工具) 大部分的都是在viewer.mjs中的const defaultOptions 变量设置默认值,可以使用数字也可以使用他们对应的变量枚举值 默认显示侧边栏(切换侧栏) 在viewer.mjs中找到defaultOptions,大概在732行,或则搜索sidebarViewOn…...
