Vue对话式前端界面

一. 对话样式的实现

用一个messages数组来存放对话信息,信息有两种类型user和bot

this.messages.push({ type: 'user', content: this.userMessage });
this.messages.push({ type: 'bot', content: response.data.reply });

模版部分使用:class="['message-content', message.type]将两种对话数据区分开来(不要忘记冒号)

<div v-for="(message, index) in messages" :key="index" :class="['message-item', message.type]">
<div :class="['message-content', message.type]" v-html="formatMessage(message.content)"></div>
</div>

相关css实现

.message-item {
  margin-right: 15%;
  margin-left: 15%;
  display: flex;
  justify-content: flex-end; /* 将用户消息放在右侧 */
  margin-bottom: 10px;
}
​
.message-item.bot {
  justify-content: flex-start; /* 将机器人消息放在左侧 */
}
​
.message-content {
  padding: 10px;
  border-radius: 10px;
  background-color: #DCF8C6; /* 用户消息背景色 */
  max-width: 100%;
  word-wrap: break-word;
}
​
.message-content.bot {
  background-color: #E0E0E0; /* 机器人消息背景色 */
}

二. 保持对话框在最底部

    scrollToBottom() {
      var div = document.getElementById('message');
      div.scrollTop = div.scrollHeight;
    },

三. 像后端模型请求回答

利用axios作为请求,用GET方法

注意,axios与request是有区别的,axios相比于request的返回数据被多封装了一层,用response.data.reply来获取数据

async sendToBackend(message) {
      try {
        const response = await axios.get('YOUR_BACKEND_API_URL', {
          message: message
        });
​
        // 假设后端返回的数据在response.data中
        this.messages.push({ type: 'bot', content: response.data.reply });
      } catch (error) {
        console.error('Error sending message:', error);
        // 可以添加错误处理逻辑
        this.messages.push({ type: 'bot', content: '出错了,请稍后再试。' });
      }
    },

四.去除页面总体的滚动条

:global(body) {
  margin: 0; /* 去除页面的默认边距 */
  padding: 0; /* 去除页面的默认内边距 */
  overflow: hidden; /* 隐藏所有内容的滚动条 */
}

五.左侧记录栏的实现

1.记录栏功能

创建新对话,查看历史对话

2.相关html代码实现

对于历史记录部分通过for循环来进行展示

​
    
<div style="display: flex">
      <div style="width: 20%; border-right: 1px solid #aaaaaa; min-height: calc(100vh - 60px)">
        <div class="history-item" style="border-bottom: 1px solid #ddd; white-space: nowrap;" @click="newQuery()">
          <card>
            <div class="new-query">
              <i class="icon el-icon-circle-plus-outline"></i>
              创建新对话
            </div>
​
          </card>
        </div>
​
        <div class="history-item">
          <card>
            <div class="history-content">
              {{ messages[0] ? messages[0].content : '您还没有提问问题' }}
            </div>
          </card>
        </div>
        <h6 style="margin-left: 10px">历史</h6>
        <div v-for="(history, index) in sortedHistories" :key="index" class="history-item"
             @click="handleHistoryClick(history)">
          <div class="history-content"> {{ history[0] ? history[0].content : 'No content available' }}</div>
        </div>
      </div>
    </div>
  </div>

3.相关JS实现

在点击历史记录的时候会将当前的对话保存,再对历史记录进行展示

 async getHistories() { // 获取历史数据
      try {
        console.log("Fetching histories..."); // 添加一个日志以确保函数调用正常
​
        const response = await axios.get('http://127.0.0.1:5000/histories');
​
        // 假设后端返回的数据在response.data中
        this.histories = response.data; // 将返回的数据存储在组件的 histories 属性中
​
        console.log(this.histories); // 打印获取的历史数据,以便调试和确认
        console.log(this.sortedHistories)
      } catch (error) {
        console.error('Error fetching histories:', error); // 如果出现错误,打印错误信息
        // 可以添加更详细的错误处理逻辑,比如显示错误信息到界面上
        console.log("Failed to fetch histories."); // 日志记录数据获取失败
      }
    }
    ,
    saveHistory() {
      if (this.messages && this.messages.length > 0 && !this.passOld) {
        this.histories.push(this.messages);
      }
    }
    ,

### 创建基于 Vue.js 的 ChatGPT 对话前端页面 为了构建一个简单的基于 Vue.js 的聊天对话界面,可以遵循以下结构和代码片段。这不仅涉及基本的 HTML 和 CSS 设置,还涉及到 Vue 实例的初始化以及如何处理用户输入并显示来自服务器的消息。 #### 初始化项目环境 确保安装了 Node.js 和 npm 后,在命令行工具中运行如下命令来创建一个新的 Vue 项目: ```bash npm init vue@latest cd your-project-name npm install ``` 对于与 ChatGPT API 进行交互的需求,还需要引入 `axios` 或其他 HTTP 请求库用于发送请求给后端服务: ```bash npm install axios ``` #### 编写组件逻辑 在 src/components 文件夹下新建名为 `ChatBox.vue` 的文件,该文件定义了一个简单的聊天框组件,其中包含了消息列表、输入区域和提交按钮等功能。 ```vue <template> <div class="chat-box"> <ul class="message-list"> <li v-for="(msg, index) in messages" :key="index">{{ msg }}</li> </ul> <div class="input-area"> <textarea v-model="newMessage"></textarea> <button @click="sendMessage">Send</button> </div> </div> </template> <script setup> import { ref } from 'vue'; import axios from 'axios'; const newMessage = ref(''); const messages = ref([]); function sendMessage() { if (newMessage.value.trim()) { const userMsg = `User: ${newMessage.value}`; messages.value.push(userMsg); // 发送新消息到服务器,并接收回复 axios.post('/api/chat', { message: newMessage.value }) .then(response => { const botReply = `Bot: ${response.data.reply}`; messages.value.push(botReply); }); newMessage.value = ''; // 清空输入框 } } </script> <style scoped> .chat-box { width: 100%; max-width: 600px; margin: auto; } .message-list { list-style-type: none; padding-left: 0; } .input-area textarea { display: block; width: calc(100% - 80px); /* 减去按钮宽度 */ height: 5em; resize: vertical; } .input-area button { float: right; } </style> ``` 此部分展示了如何利用 Vue 组件特性快速搭建起具有响应式的 UI 界面[^1]。 #### 配置路由和服务接口 为了让应用程序能够正常工作,还需设置好相应的路由规则和服务端点映射关系。假设已经有一个可用的服务地址 `/api/chat` 可供调用,则无需额外修改;否则应根据实际情况调整路径或部署自己的网关层来进行转发。 此外,考虑到安全性因素,建议采用 HTTPS 协议连接至目标站点,并实施必要的身份验证机制以保护敏感信息传输过程中的隐私安全。 #### 主应用入口 App.vue 修改 最后一步是在项目的根目录下的 `App.vue` 中导入刚刚创建好的 `ChatBox` 组件,并将其作为默认展示的内容之一。 ```vue <template> <main> <h1>Welcome to My Chat Application!</h1> <ChatBox /> </main> </template> <script setup> import ChatBox from './components/ChatBox.vue' </script> ``` 这样就完成了一个简易版本的基于 Vue.js 技术栈开发的在线聊天室原型设计[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值