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);
      }
    }
    ,

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值