国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

chatgpt這么火?前端如何實(shí)現(xiàn)類似chatgpt的對話頁面

這篇具有很好參考價(jià)值的文章主要介紹了chatgpt這么火?前端如何實(shí)現(xiàn)類似chatgpt的對話頁面。希望對大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

?? 個(gè)人簡介

  • ?? 作者簡介:大家好,我是阿牛,全棧領(lǐng)域優(yōu)質(zhì)創(chuàng)作者??
  • ?? 個(gè)人主頁:館主阿牛??
  • ?? 支持我:點(diǎn)贊??+收藏??+留言??
  • ?? 系列專欄:前端實(shí)用小demo??
  • ??格言:迄今所有人生都大寫著失敗,但不妨礙我繼續(xù)向前!??

chatgpt前端頁面,前端實(shí)用小demo,ChatGPT指南,前端,chatgpt,css

前言

自從去年11月份chatgpt出圈之后,他的熱度就居高不減,也出現(xiàn)了很多人借助接口開發(fā)的國內(nèi)版本,那么本篇博客就從前端的角度來看看前端如何實(shí)現(xiàn)類似chatgpt的對話功能!

最終效果

源碼在文末獲取!

chatgpt前端頁面,前端實(shí)用小demo,ChatGPT指南,前端,chatgpt,css
因?yàn)檫@是我寫在一個(gè)項(xiàng)目中的,單獨(dú)提出來可能配色效果不同,但功能和做法只要我們掌握了,那么自己想怎么寫就怎么寫!

頁面布局

這一塊比較簡單,分析過chatgpt的頁面的就會知道,他的頁面布局方式是采用flex布局的,flex布局確實(shí)好用,那么我也是基于Bootsrap+jquery+flex布局完成了簡易版的對話功能!主要有兩個(gè)地方用到了flex布局!

flex布局一

chatgpt前端頁面,前端實(shí)用小demo,ChatGPT指南,前端,chatgpt,css
這里的頭像和文字采用的就是flex布局,并且文字和圖片頂部對齊,防止文字較多依舊和圖片中間對齊的bug。
需要設(shè)置css:

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

其中align-items: flex-start;的作用就是讓文字與圖片頂部對齊!

chatgpt前端頁面,前端實(shí)用小demo,ChatGPT指南,前端,chatgpt,css

flex布局二(重點(diǎn))

第二處用到flex布局的地方就是這個(gè)搜索框:
chatgpt前端頁面,前端實(shí)用小demo,ChatGPT指南,前端,chatgpt,css
很多人覺得這個(gè)對話框很簡單,flex布局實(shí)現(xiàn)輸入框和按鈕在同一行確實(shí)簡單,但你要好好看看chatgpt的官網(wǎng),都是有小細(xì)節(jié)的,這里面還是有很多知識點(diǎn)的。

首先,我要說的是這個(gè)輸入框用的textarea,而不是input,區(qū)別在于,input輸入的內(nèi)容是不能換行的,但textarea文本框可以,但使用textarea的問題是,參數(shù)rows設(shè)置為一行,這個(gè)文本框的高度會很低,達(dá)不到chatgpt的那個(gè)頁面要求,rows設(shè)置大一點(diǎn)或者這個(gè)文本框的高度給高一點(diǎn)會有一個(gè)問題就是輸入時(shí)他的光標(biāo)不會在文本框的高度中間,而是在第一行,我們是沒法通過其他方式讓輸入光標(biāo)垂直居中的,因此這也不符合chatgpt頁面的要求,所以這確實(shí)是個(gè)值的學(xué)習(xí)的一點(diǎn)!看了chatgpt頁面的做法后,我悟了,下面一張圖來說明chatgpt是如何做的:

chatgpt前端頁面,前端實(shí)用小demo,ChatGPT指南,前端,chatgpt,css
如圖,你只要將textarea邊框取消掉,然后focus偽類將邊框效果也取消掉,外邊再套一個(gè)div邊框?qū)extarea文本框和按鈕套在里面就好了!

.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;
}

最后,將這個(gè)輸入框定位到頁面底部就好!

js部分

首先,頁面部分,我們添加消息到頁面,包括用戶的問題以及ai的回復(fù),添加消息到頁面時(shí)需要向上滾動(dòng):

// 添加用戶消息到窗口
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);
}

// 添加回復(fù)消息到窗口
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);
}

這里消息添加帶頁面后,清空了輸入框的內(nèi)容,接下來還需要給輸入框添加加一個(gè)鍵盤事件,也就是點(diǎn)擊enter鍵也可以發(fā)送消息!

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

最后就是發(fā)送消息與獲得消息的一部分了:

// 處理用戶輸入
chatBtn.click(function() {
  var message = chatInput.val();
  if (message.length == 0){
    common_ops.alert("請輸入內(nèi)容!")  // 彈窗  
    return  
  }
  addUserMessage(message);
  
  chatBtn.attr('disabled',true) // 消息發(fā)送后讓提交按鈕不可點(diǎn)擊

  // 發(fā)送信息到后臺
  $.ajax({
    url: '/chat',
    method: 'POST',
    data: {
      "prompt": JSON.stringify(message)
    },
    success: function(res) {
      res = JSON.parse(res);
      addBotMessage(res.content);
      chatBtn.attr('disabled',false)  // 成功接受消息后讓提交按鈕再次可以點(diǎn)擊
    },
    error: function(jqXHR, textStatus, errorThrown) {
      addBotMessage('<span style="color:red;">' + '出錯(cuò)啦!請稍后再試!' + '</span>');
      chatBtn.attr('disabled',false) 
    }
  });
});

這些邏輯都很簡單,我不再總結(jié),需要注意的是,我在發(fā)送消息到后臺等待相應(yīng)的過程讓按鈕的狀態(tài)是不可點(diǎn)擊的,直到后臺返回消息才可以進(jìn)行下一次問答!但這里我沒有處理鍵盤事件,也就是說你可以點(diǎn)擊enter繼續(xù)向后臺發(fā)送消息,這也是一個(gè)bug,只不過我沒有處理,你們不需要的可以去掉這個(gè)鍵盤事件就好了,當(dāng)然也可以在發(fā)送消息到獲得回答的這個(gè)時(shí)間段像禁用發(fā)送按鈕一樣,禁止enter鍵盤事件或者解綁這個(gè)鍵盤事件,這個(gè)你們自己去完成,這里我不在多說(總要留點(diǎn)東西讓你們自己去思考去感悟!)

完整代碼

<!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="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>
              <h1 class="text-center m-b-lg">Chat with ChatGPT</h1>
            </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);
        }

        // 添加回復(fù)消息到窗口
        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("請輸入內(nèi)容!")    
            return  
          }
          addUserMessage(message);

          // messages.push({"role": "user", "content": message})
          
          chatBtn.attr('disabled',true) // 消息發(fā)送后讓提交按鈕不可點(diǎn)擊

          // 發(fā)送信息到后臺
          $.ajax({
            url: '/chat',
            method: 'POST',
            data: {
              "prompt": JSON.stringify(message)
            },
            success: function(res) {
              res = JSON.parse(res);
              addBotMessage(res.content);
              chatBtn.attr('disabled',false)  // 成功接受消息后讓提交按鈕再次可以點(diǎn)擊
            },
            error: function(jqXHR, textStatus, errorThrown) {
              addBotMessage('<span style="color:red;">' + '出錯(cuò)啦!請稍后再試!' + '</span>');
              chatBtn.attr('disabled',false) 
            }
          });
        });

        // 處理 Enter 鍵按下
        chatInput.keypress(function(e) {
          if (e.which == 13) {
            chatBtn.click();
          }
        });
  });
</script>
</html>

這里面用到的layer.js就是一個(gè)彈窗組件,百度可以搜到,common.js是我自己對layer.js方法的封裝,這個(gè)頁面其實(shí)你不這兩個(gè)js文件也行,因?yàn)檎麄€(gè)頁面只有下面的代碼用到了彈窗:

if (message.length == 0){
 	common_ops.alert("請輸入內(nèi)容!")    
  	return  
}

其實(shí)簡陋點(diǎn),一個(gè)alert就搞定了!

結(jié)語

如果你覺得博主寫的還不錯(cuò)的話,可以訂閱下面的這個(gè)flask專欄,這是博主唯一的付費(fèi)專欄,我做的這個(gè)頁面也是最近項(xiàng)目的一部分,這個(gè)項(xiàng)目也是用flask做的,我會將他全部總結(jié)開源到這個(gè)flask專欄中。

【flask從入門到實(shí)戰(zhàn)】專欄9.9火熱訂閱中,已包含兩個(gè)項(xiàng)目,全站獨(dú)一無二的腳手架搭建,直接復(fù)制簡單無腦操作,項(xiàng)目結(jié)構(gòu)類似Django,感興趣的可以看看哦!

??系列專欄
??flask框架快速入門

其他專欄請前往博主主頁查看!文章來源地址http://www.zghlxwxcb.cn/news/detail-778357.html

到了這里,關(guān)于chatgpt這么火?前端如何實(shí)現(xiàn)類似chatgpt的對話頁面的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 發(fā)現(xiàn)最優(yōu)秀的類似chatgpt的人工智能對話體驗(yàn)

    發(fā)現(xiàn)最優(yōu)秀的類似chatgpt的人工智能對話體驗(yàn)

    Tomchat:點(diǎn)擊傳送 支持gpt4 / gpt-3.5 / claude 支持 AI繪畫 每天十次免費(fèi)使用機(jī)會 無需魔法 wuguokai 這個(gè)網(wǎng)站是設(shè)計(jì)模式老師推薦的,不強(qiáng)制用戶。并且滿足毫秒級響應(yīng)。 https://chat.wuguokai.cn AIDuTu 無需登錄,直接使用,挺好的 https://chat.jubianxingqiu.com/

    2024年02月14日
    瀏覽(24)
  • 仿chatGPT或chatPDF的前端界面布局,css實(shí)現(xiàn)對話聊天布局代碼,響應(yīng)式左右分欄布局(附完整源代碼)

    仿chatGPT或chatPDF的前端界面布局,css實(shí)現(xiàn)對話聊天布局代碼,響應(yīng)式左右分欄布局(附完整源代碼)

    chatPDF或者chatGPT的界面挺簡潔的,就是一個(gè)左側(cè)的列表以及右側(cè)的對話列表,現(xiàn)在使用css實(shí)現(xiàn)這樣的布局 充分運(yùn)用了flex布局方式實(shí)現(xiàn),左右分欄,以及對話形式展示效果 下面是效果圖: ? 在手機(jī)設(shè)備看就隱藏左側(cè),右側(cè)100%適應(yīng) ?下面就是html和css的布局代碼 ?

    2023年04月22日
    瀏覽(29)
  • 如何實(shí)現(xiàn)前端單頁面應(yīng)用(SPA)?

    如何實(shí)現(xiàn)前端單頁面應(yīng)用(SPA)?

    聚沙成塔·每天進(jìn)步一點(diǎn)點(diǎn) 前端入門之旅:探索Web開發(fā)的奇妙世界 歡迎來到前端入門之旅!感興趣的可以訂閱本專欄哦!這個(gè)專欄是為那些對Web開發(fā)感興趣、剛剛踏入前端領(lǐng)域的朋友們量身打造的。無論你是完全的新手還是有一些基礎(chǔ)的開發(fā)者,這里都將為你提供一個(gè)系統(tǒng)而

    2024年02月08日
    瀏覽(21)
  • 工作這么久了,還不懂如何使用純前端實(shí)現(xiàn)分頁嗎?-假如后端一股腦返回給你所有數(shù)據(jù),讓你自個(gè)實(shí)現(xiàn)分頁該怎么辦

    工作這么久了,還不懂如何使用純前端實(shí)現(xiàn)分頁嗎?-假如后端一股腦返回給你所有數(shù)據(jù),讓你自個(gè)實(shí)現(xiàn)分頁該怎么辦

    有這么個(gè)場景,后端接口的列表數(shù)據(jù)沒有做分頁給我,相當(dāng)于是直接返回所有的列表數(shù)據(jù),比如有100條就返回100,但是前端顯示,則需要做成分頁,比如10條為一頁。 假如你用vue來實(shí)現(xiàn),思路就是將數(shù)據(jù)切割,然后分批顯示。 所以可以使用 computed 計(jì)算屬性和 v-for 指令來實(shí)現(xiàn)

    2024年04月17日
    瀏覽(20)
  • 前端如何實(shí)現(xiàn)隱藏滾動(dòng)條,并且頁面還可以滾動(dòng)

    在前端中,可以通過 CSS 和一些簡單的樣式調(diào)整來實(shí)現(xiàn)隱藏滾動(dòng)條,同時(shí)保持頁面可滾動(dòng)。這通常涉及到在容器內(nèi)部創(chuàng)建滾動(dòng)區(qū)域,并隱藏默認(rèn)的滾動(dòng)條樣式。 下面是實(shí)現(xiàn)這一效果的基本步驟: 創(chuàng)建一個(gè)滾動(dòng)容器元素,使其包裹需要滾動(dòng)的內(nèi)容。 通過 CSS 隱藏默認(rèn)的滾動(dòng)條樣

    2024年02月02日
    瀏覽(24)
  • 如何緩解高考前緊張的情緒,ChatGPT這么說......

    如何緩解高考前緊張的情緒,ChatGPT這么說......

    明天就要高考了,看到家長有各種打氣的做法,既有上靈隱寺的,也有穿著旗袍希望旗開得勝的,還有說什么失敗了不要緊的......,反正都是焦慮的不行。 面對高考,大多考生都會緊張,但適度的緊張對發(fā)揮出考生的水平有幫助,但家長各種突破常規(guī)的加油做法則會適得其反

    2024年02月08日
    瀏覽(13)
  • vue3 實(shí)現(xiàn)門戶網(wǎng)站頁面鼠標(biāo)滾輪控制頁面上下滾動(dòng)---類似輪播圖

    案例參考:首頁_CNESA 儲能研究平臺 //監(jiān)聽鼠標(biāo)滾動(dòng)事件 ?window.addEventListener(\\\'mousewheel\\\', debounce(methodB,300), true)||window.addEventListener(\\\"DOMMouseScroll\\\",debounce(methodB,300),false) const debounce = (func, wait) ={ ? ? ? ? let timeout; ? ? ? ? return ?function() { ? ? ? ? ? ? let context = this; ? ? ? ? ? ?

    2024年02月12日
    瀏覽(172)
  • 如何學(xué)習(xí)和規(guī)劃類似ChatGPT這種人工智能(AI)相關(guān)技術(shù)

    學(xué)習(xí)和規(guī)劃類似ChatGPT這種人工智能(AI)相關(guān)技術(shù)的路徑通常包括以下步驟: 學(xué)習(xí)基礎(chǔ)知識 : 學(xué)習(xí)編程:首先,你需要學(xué)習(xí)一種編程語言,例如Python,這是大多數(shù)人工智能項(xiàng)目的首選語言。 數(shù)學(xué)基礎(chǔ):深度學(xué)習(xí)和自然語言處理等領(lǐng)域需要一定的數(shù)學(xué)基礎(chǔ),包括線性代數(shù)、微

    2024年02月19日
    瀏覽(18)
  • 前端實(shí)現(xiàn)復(fù)制文字和圖片,原來這么簡單!

    前端實(shí)現(xiàn)復(fù)制文字和圖片,原來這么簡單!

    實(shí)習(xí)工作中,遇到一個(gè)需求,需要完成點(diǎn)擊復(fù)制的功能,當(dāng)文字過長的時(shí)候,讓用戶手拖再ctrl+c這種方式體驗(yàn)就不是很好了,如果可以點(diǎn)擊一下直接復(fù)制就是一種不錯(cuò)的優(yōu)化用戶體驗(yàn)的方式。 經(jīng)過查閱文檔,網(wǎng)絡(luò)上完成這個(gè)功能大多使用兩大類方法 第一種是以document.execCom

    2024年02月11日
    瀏覽(24)
  • 微信小程序?qū)崿F(xiàn)頁面數(shù)據(jù)偵聽器,類似vue的watch

    既然小程序的組件已經(jīng)有Observer功能,那為什么還要手寫watch功能呢? Observer只能在Component中使用,沒法在Page中使用。若是想在Page中監(jiān)控某一數(shù)據(jù)的變化,Observer做不到。 Observer屬于小程序的新功能,只能在高版本微信使用,低版本微信無法使用。公司的小程序就因?yàn)槭褂昧?/p>

    2024年02月03日
    瀏覽(27)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包