iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >前端如何实现类似chatgpt的对话页面
  • 873
分享到

前端如何实现类似chatgpt的对话页面

2023-07-05 11:07:47 873人浏览 泡泡鱼
摘要

本文小编为大家详细介绍“前端如何实现类似chatgpt的对话页面”,内容详细,步骤清晰,细节处理妥当,希望这篇“前端如何实现类似chatgpt的对话页面”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。页面布局这一块

本文小编为大家详细介绍“前端如何实现类似chatgpt的对话页面”,内容详细,步骤清晰,细节处理妥当,希望这篇“前端如何实现类似chatgpt的对话页面”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

页面布局

这一块比较简单,分析过chatgpt的页面的就会知道,他的页面布局方式是采用flex布局的,flex布局确实好用,那么我也是基于Bootsrap+Jquery+flex布局完成了简易版的对话功能!主要有两个地方用到了flex布局!

flex布局一

前端如何实现类似chatgpt的对话页面

这里的头像和文字采用的就是flex布局,并且文字和图片顶部对齐,防止文字较多依旧和图片中间对齐的bug。
需要设置CSS:

display: flex;align-items: flex-start;

其中align-items: flex-start;的作用就是让文字与图片顶部对齐!

前端如何实现类似chatgpt的对话页面

flex布局二(重点)

第二处用到flex布局的地方就是这个搜索框:

前端如何实现类似chatgpt的对话页面

很多人觉得这个对话框很简单,flex布局实现输入框和按钮在同一行确实简单,但你要好好看看chatgpt的官网,都是有小细节的,这里面还是有很多知识点的。

首先,我要说的是这个输入框用的textarea,而不是input,区别在于,input输入的内容是不能换行的,但textarea文本框可以,但使用textarea的问题是,参数rows设置为一行,这个文本框的高度会很低,达不到chatgpt的那个页面要求,rows设置大一点或者这个文本框的高度给高一点会有一个问题就是输入时他的光标不会在文本框的高度中间,而是在第一行,我们是没法通过其他方式让输入光标垂直居中的,因此这也不符合chatgpt页面的要求,所以这确实是个值的学习的一点!看了chatgpt页面的做法后,我悟了,下面一张图来说明chatgpt是如何做的:

前端如何实现类似chatgpt的对话页面

如图,你只要将textarea边框取消掉,然后focus伪类将边框效果也取消掉,外边再套一个div边框将textarea文本框和按钮套在里面就好了!

.ipt{   display:flex;   align-items: center;   position: absolute;   bottom: 60px;   margin: 0 15px;   padding-right: 15px;   border-radius: 15px;   width: calc(100% - 30px);   height: 50px;   border: 1px solid #e7eaec;}.ipt textarea {   resize: none;   overflow-y: auto;   border: none;   box-shadow: none;}.ipt textarea:focus{   border: none !important;   box-shadow: none !important;}

最后,将这个输入框定位到页面底部就好!

js部分

首先,页面部分,我们添加消息到页面,包括用户的问题以及ai的回复,添加消息到页面时需要向上滚动:

// 添加用户消息到窗口function addUserMessage(message) {  var messageElement = $('<div class="row message-bubble"><img class="chat-icon" src="' + userIcon + '"><p class="message-text">' + message + '</p></div>');  chatWindow.append(messageElement);  chatInput.val('');  chatWindow.animate({ scrollTop: chatWindow.prop('scrollHeight') }, 500);}// 添加回复消息到窗口function addBotMessage(message) {  var messageElement = $('<div class="row message-bubble"><img class="chat-icon" src="' + botIcon + '"><p class="message-text">' + message + '</p></div>');  chatWindow.append(messageElement);  chatInput.val('');  chatWindow.animate({ scrollTop: chatWindow.prop('scrollHeight') }, 500);}

这里消息添加带页面后,清空了输入框的内容,接下来还需要给输入框添加加一个键盘事件,也就是点击enter键也可以发送消息!

// 处理 Enter 键按下chatInput.keypress(function(e) {  if (e.which == 13) {    chatBtn.click();  }});

最后就是发送消息与获得消息的一部分了:

// 处理用户输入chatBtn.click(function() {  var message = chatInput.val();  if (message.length == 0){    common_ops.alert("请输入内容!")  // 弹窗      return    }  addUserMessage(message);    chatBtn.attr('disabled',true) // 消息发送后让提交按钮不可点击  // 发送信息到后台  $.ajax({    url: '/chat',    method: 'POST',    data: {      "prompt": JSON.stringify(message)    },    success: function(res) {      res = JSON.parse(res);      addBotMessage(res.content);      chatBtn.attr('disabled',false)  // 成功接受消息后让提交按钮再次可以点击    },    error: function(jqXHR, textStatus, errorThrown) {      addBotMessage('<span >' + '出错啦!请稍后再试!' + '</span>');      chatBtn.attr('disabled',false)     }  });});

这些逻辑都很简单,我不再总结,需要注意的是,我在发送消息到后台等待相应的过程让按钮的状态是不可点击的,直到后台返回消息才可以进行下一次问答!但这里我没有处理键盘事件,也就是说你可以点击enter继续向后台发送消息,这也是一个bug,只不过我没有处理,你们不需要的可以去掉这个键盘事件就好了,当然也可以在发送消息到获得回答的这个时间段像禁用发送按钮一样,禁止enter键盘事件或者解绑这个键盘事件,这个你们自己去完成,这里我不在多说(总要留点东西让你们自己去思考去感悟!)

完整代码

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <meta Http-equiv="X-UA-Compatible" content="IE=edge">    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <link href="../../static/css/bootstrap.min.css" rel="external nofollow"  rel="stylesheet">    <title>chat</title>    <style>        .answer{          width: 100%;          position: relative;          height: 70vh;        }            .ipt{          display:flex;          align-items: center;          position: absolute;          bottom: 60px;          margin: 0 15px;          padding-right: 15px;          border-radius: 15px;          width: calc(100% - 30px);          height: 50px;          border: 1px solid #e7eaec;        }        .ipt textarea {          resize: none;          overflow-y: auto;          border: none;          box-shadow: none;        }        .ipt textarea:focus{            border: none !important;            box-shadow: none !important;        }        #chatWindow {          max-height: calc(70vh - 120px);          height:auto;          overflow-y: auto;        }            .message-bubble {            padding: 10px;            margin: 5px;            display: flex;            align-items: flex-start;            border-bottom: 1px dashed #e7eaec;        }                .message-bubble p {            font-size: 18px;            margin-left:15px;        }            .chat-icon {            width: 30px;            height: 30px;            border-radius: 3px;        }    </style></head><body>    <div>      <div class="row">          <div class="col-xs-12">            <div>              <h2 class="text-center m-b-lg">Chat with ChatGPT</h2>            </div>            <div class="answer">              <div id="chatWindow" class="mb-3"></div>              <div class="input-group ipt">                <div class="col-xs-12">                  <textarea id="chatInput" class="fORM-control" rows="1"></textarea>                </div>                <button id="chatBtn" class="btn btn-primary" type="button">Go !</button>              </div>            </div>          </div>        </div>      </div>    </div> </body><script src="../../static/plugins/jquery-2.1.1.js"></script><script src="../../static/js/bootstrap.min.js"></script><script src="../../static/plugins/layer/layer.js"></script><script src="../../static/js/common.js"></script><script>    $(document).ready(function() {        var chatBtn = $('#chatBtn');        var chatInput = $('#chatInput');        var chatWindow = $('#chatWindow');        var userIcon = '/static/images/user/{{ current_user.avatar }}'        var botIcon = '/static/images/aichat/chatgpt.png';                // 添加用户消息到窗口        function addUserMessage(message) {          var messageElement = $('<div class="row message-bubble"><img class="chat-icon" src="' + userIcon + '"><p class="message-text">' + message + '</p></div>');          chatWindow.append(messageElement);          chatInput.val('');          chatWindow.animate({ scrollTop: chatWindow.prop('scrollHeight') }, 500);        }        // 添加回复消息到窗口        function addBotMessage(message) {          var messageElement = $('<div class="row message-bubble"><img class="chat-icon" src="' + botIcon + '"><p class="message-text">' + message + '</p></div>');          chatWindow.append(messageElement);          chatInput.val('');          chatWindow.animate({ scrollTop: chatWindow.prop('scrollHeight') }, 500);        }        // 处理用户输入        chatBtn.click(function() {          var message = chatInput.val();          if (message.length == 0){            common_ops.alert("请输入内容!")                return            }          addUserMessage(message);          // messages.push({"role": "user", "content": message})                    chatBtn.attr('disabled',true) // 消息发送后让提交按钮不可点击          // 发送信息到后台          $.ajax({            url: '/chat',            method: 'POST',            data: {              "prompt": JSON.stringify(message)            },            success: function(res) {              res = JSON.parse(res);              addBotMessage(res.content);              chatBtn.attr('disabled',false)  // 成功接受消息后让提交按钮再次可以点击            },            error: function(jqXHR, textStatus, errorThrown) {              addBotMessage('<span >' + '出错啦!请稍后再试!' + '</span>');              chatBtn.attr('disabled',false)             }          });        });        // 处理 Enter 键按下        chatInput.keypress(function(e) {          if (e.which == 13) {            chatBtn.click();          }        });  });</script></html>

这里面用到的layer.js就是一个弹窗组件,百度可以搜到,common.js是我自己对layer.js方法的封装,这个页面其实你不这两个js文件也行,因为整个页面只有下面的代码用到了弹窗:

if (message.length == 0){ common_ops.alert("请输入内容!")      return  }

其实简陋点,一个alert就搞定了!

读到这里,这篇“前端如何实现类似chatgpt的对话页面”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: 前端如何实现类似chatgpt的对话页面

本文链接: https://www.lsjlt.com/news/351502.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 前端如何实现类似chatgpt的对话页面
    本文小编为大家详细介绍“前端如何实现类似chatgpt的对话页面”,内容详细,步骤清晰,细节处理妥当,希望这篇“前端如何实现类似chatgpt的对话页面”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。页面布局这一块...
    99+
    2023-07-05
  • 前端实现类似chatgpt的对话页面(案例)
    目录前言最终效果页面布局flex布局一flex布局二(重点)js部分完整代码结语前言 自从去年11月份chatgpt出圈之后,他的热度就居高不减,也出现了很多人借助接口开发的国内版本...
    99+
    2023-03-13
    chatgpt对话功能 chatgpt对话
  • Android如何实现类似iOS风格的对话框
    这篇文章将为大家详细讲解有关Android如何实现类似iOS风格的对话框,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。分享一个简单的常用的对话框类,按照国际惯例,先上图布局简单,先上布局。一个标题,一个内...
    99+
    2023-05-30
    android ios
  • vue如何实现前端分页
    Vue可以通过以下几种方式来实现前端分页:1. 使用Vue自带的v-for指令和计算属性:可以将数据和页码信息存储在Vue的data...
    99+
    2023-08-09
    vue
  • 如何利用ChatGPT和Python实现多轮对话管理
    如何利用ChatGPT和Python实现多轮对话管理引言:随着人工智能技术的快速发展,Chatbot(聊天机器人)已成为各类应用的重要组成部分。多轮对话是Chatbot中的一个关键问题,它要求Chatbot能够理解用户的多个连续发言,并给出...
    99+
    2023-10-24
    ChatGPT Python 多轮对话管理
  • ASP.NET如何关闭页面服务端及对话层清空
    这篇文章给大家介绍ASP.NET如何关闭页面服务端及对话层清空,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。要清掉Session必须回到服务端,在客户端是不能改变服务端内容的。ASP.NET 关闭页面服务端对话层的清空...
    99+
    2023-06-17
  • 如何利用ChatGPT和Python实现对话历史分析
    如何利用ChatGPT和Python实现对话历史分析引言:人工智能的发展给自然语言处理带来了重大突破。OpenAI的ChatGPT模型是一种强大的语言生成模型,能够生成连贯、合理的文本回复。本文将介绍如何使用ChatGPT和Python实现...
    99+
    2023-10-25
    ChatGPT Python 对话历史分析
  • Vue实现前端页面缓存的过程
    目录Vue前端页面缓存1.使用情景2.keep-alive基本认识3.keep-alive实现路由页面缓存vue页面缓存问题1.路由设置2.页面路由嵌套设置3.从指定页面返回使用缓存...
    99+
    2024-04-02
  • 如何利用ChatGPT和Python实现多模态对话功能
    如何利用ChatGPT和Python实现多模态对话功能概述:随着人工智能技术的发展,多模态对话逐渐成为了研究和应用的热点。多模态对话不仅包括文本对话,还可以通过图像、音频和视频等多种媒体形式进行交流。本文将介绍如何利用ChatGPT和Pyt...
    99+
    2023-10-26
    ChatGPT Python 多模态对话
  • iOS UITextView如何实现类似微博的话题、提及用户效果
    这篇文章主要介绍“iOS UITextView如何实现类似微博的话题、提及用户效果”,在日常操作中,相信很多人在iOS UITextView如何实现类似微博的话题、提及用户效果问题上存在疑惑,小编查阅了各式资料,整理出简...
    99+
    2023-07-02
  • 如何利用ChatGPT和Python实现对话事件的时序管理
    如何利用ChatGPT和Python实现对话事件的时序管理引言:随着人工智能的快速发展,ChatGPT作为一种基于大规模预训练模型的对话生成模型,已经成为自然语言处理领域的热门技术之一。然而,仅凭ChatGPT本身还无法实现对话事件的时序管...
    99+
    2023-10-24
    ChatGPT Python 对话事件管理
  • AngularJs如何实现返回前一页面时刷新一次前面页面
    小编给大家分享一下AngularJs如何实现返回前一页面时刷新一次前面页面,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!要求:页...
    99+
    2024-04-02
  • 如何利用ChatGPT和Python实现对话情感分析功能
    如何利用ChatGPT和Python实现对话情感分析功能引言:随着人工智能和自然语言处理的快速发展,对话情感分析成为了一个备受关注的研究领域。ChatGPT作为一个先进的生成式对话模型,为我们提供了一个很好的工具来实现对话情感分析。本文将介...
    99+
    2023-10-24
    ChatGPT Python 对话情感分析
  • LayUI如何实现前端分页功能
    这篇文章主要为大家展示了“LayUI如何实现前端分页功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“LayUI如何实现前端分页功能”这篇文章吧。一、LayUI...
    99+
    2024-04-02
  • 如何利用ChatGPT和Python实现情景生成对话功能
    如何利用ChatGPT和Python实现情景生成对话功能引言:近年来,自然语言处理技术发展迅猛,其中一项重要技术就是对话模型。OpenAI的ChatGPT是一种非常强大的对话模型,它可以理解和生成人类语言。本文将介绍如何利用ChatGPT和...
    99+
    2023-10-25
    ChatGPT Python 情景生成对话
  • 如何实现html5各种页面切换效果和模态对话框
    本篇内容介绍了“如何实现html5各种页面切换效果和模态对话框”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2024-04-02
  • 前端面试官常问的问题:如何实现前端路由?
    前端面试官常问的问题:如何实现前端路由? 前端开发是近年来蓬勃发展的领域,技术的不断更新也让前端开发人员面临着更多的挑战与机遇。在前端开发面试中,前端路由是一个经常被问及的话题之一。实...
    99+
    2024-04-02
  • 如何在web页面中实现类似excel固定表头或标题行的效果
    这篇文章将为大家详细讲解有关如何在web页面中实现类似excel固定表头或标题行的效果,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 如果没有报表工具或者使用的开源报表工具中没有固定表头功能...
    99+
    2023-06-03
  • 如何实现Web前端页面跳转并取到值的示例分析
    这篇文章将为大家详细讲解有关如何实现Web前端页面跳转并取到值的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。这个是A页面这是B页面通过点击A页面上的添加日志 跳...
    99+
    2024-04-02
  • JavaScript如何实现前端网页版倒计时
    小编给大家分享一下JavaScript如何实现前端网页版倒计时,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!效果代码// An highlig...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作