当前位置: 首页 > wzjs >正文

网站建设虚线的代码上海网站优化推广公司

网站建设虚线的代码,上海网站优化推广公司,哈尔滨全国网站建设,如何做网站上抓视频渲染聊天数据 这个不必多说,直接从stores/chat中取出聊天列表数据渲染就好,因为前面添加的消息都是按照用户消息、AI助手消息这样添加的,效果如图 但是需要注意每条助手消息的状态,需要根据状态显示不同的图标或不显示图标&…

渲染聊天数据

这个不必多说,直接从stores/chat中取出聊天列表数据渲染就好,因为前面添加的消息都是按照用户消息、AI助手消息这样添加的,效果如图
在这里插入图片描述

但是需要注意每条助手消息的状态,需要根据状态显示不同的图标或不显示图标,比如,正常完成的回答,不显示图标,如果是调用流式回调的接口出错的或者中途停止的,且是chatRecordList中的最后一条消息,那么就要显示重新生成的图标,点击重新生成会重新发送消息
重新发送的逻辑处理,主要是找到当前的AI助手消息将其状态变为stop停止状态,然后找到当前AI助手消息之前的最后一条用户消息获取其content,去调用stores/chat中的startChat方法从而走到聊天处理逻辑的文件中去

const handleRefresh = async messageId => {try {const message = props.messages.find(msg => msg.id === messageId)if (message && message.role === 'assistant') {// 设置为等待状态message.status = 'stop'// 找到当前助手消息之前的最后一条用户消息const messageIndex = props.messages.findIndex(msg => msg.id === messageId)let lastUserMessage = nullfor (let i = messageIndex; i >= 0; i--) {if (props.messages[i].role === 'user') {lastUserMessage = props.messages[i]break}}if (lastUserMessage) {try {// 直接使用用户消息重新请求await chatStore.startChat(lastUserMessage.content)} catch (error) {// 如果失败,恢复原状态message.status = 'error'console.error('重新生成失败:', error)}}}} catch (error) {console.error('处理重新生成失败:', error)}
}

生成AI助手消息时,滚动条自动滚动向下

在聊天时要自动滚动到最新消息的位置,使用户能看到最新的消息
因为已聊天组件和未聊天组件的切换写在Chat.vue页面中,所以scrollToBottom定义到Chat.vue中才能正常的实现这个功能
在这里插入图片描述
通过scrollTo方法将top设为container.scrollHeight即元素内容的总高度,包括由于滚动而看不见的内容,浏览器会将滚动条的位置设置为元素内容的底部,由于scrollHeight是元素内容的总高度,因此滚动条会被移动到内容的最底部,从而实现滚动到底部的效果

// 滚动到底部
const scrollToBottom = () => {setTimeout(() => {const container = document.querySelector('.chat-container')if (container) {container.scrollTo({top: container.scrollHeight,behavior: 'smooth'})}}, 100)
}

当chatRecordList变化的时候,自动触发滚动到底部的函数,isClickThought是因为在显示正式的回答前会显示思考的过程,思考完成后,开始回答问题时,会将思考的内容收起,通过点击按钮控制思考内容的显示与隐藏,但是当点击思考内容变化的时候,我们是不希望滚动条滚动的,所以就通过isClickThought来控制

watch(() => chatRecordList.value,async (newList, oldList) => {await nextTick()if (!isClickThought.value) {scrollToBottom()// 短暂延迟后检查滚动位置setTimeout(() => {isScrolledToBottom()}, 100)}isClickThought.value = false},{ deep: true }
)

当消息特别多的时候,有时候可能需要查看之前的聊天内容,查看完成后可能需要继续提问,但是由于内容特别多,手动往下翻肯定费劲,所以需要一个“置底”按钮,这个按钮只有在没有消息生成的时候才会出现,不然滚动条变化的时候页面显示不友好,点击的时候直接调用scrollToBottom函数就行,isScrolledToBottom判断是否显示该按钮

const isScrolledToBottom = () => {const container = chatContainer.valueif (!container) return true// 计算是否接近底部(允许20px的误差)const isAtBottom = container.scrollHeight - container.scrollTop - container.clientHeight < 20isShowToBottom.value = !isAtBottom && !isResponding.value
}

停止当前对话和开启新对话功能

通过计算属性isResponding判断是显示“停止”还是显示“开启新对话”,当进入已聊天界面且没有正在回答的消息的时候,显示“开启新对话”按钮,否则显示停止
在这里插入图片描述

const isResponding = computed(() => {const lastMessage = chatRecordList.value[chatRecordList.value.length - 1]return lastMessage?.role === 'assistant' && ['thinking', 'typing'].includes(lastMessage.status)
})

点击停止按钮
触发chatStore中的停止响应函数

const handleStopResponse = () => {chatStore.stopResponse()
}

stores/chat.js,其中isResponseStopped是在chat.service.js判断是否需要停止响应用到的

  const isResponseStopped = ref(false) //是否停止响应function stopResponse() {isResponseStopped.value = true// 确保调用 abortRequestabortRequest()const lastMessage = chatRecordList.value[chatRecordList.value.length - 1]//获取到最后一条聊天记录if (lastMessage && lastMessage.role === 'assistant') {if (lastMessage.status === 'thinking') {//如果当前AI助手消息的状态是思考中则将状态变为stop停止状态lastMessage.status = 'stop'} else if (lastMessage.status === 'typing') {//如果当前AI助手消息的状态是已经构建回答但尚未完成,则将状态设为已完成lastMessage.status = 'done'}}}

如果当前停止的消息是最后一条AI助手消息那么就又会有handleRefresh
点击开启新会话
开启新会话调用chatStore.newChat()方法

const handleNewChat = () => {chatStore.newChat()
}

stores/chat.js
开启新对话要把之前的对话列表、是否已聊天等状态重置

  // 清除聊天状态const clearChatState = () => {hasChatted.value = falsechatRecordList.value = []assistantMessageId.value = nullisResponseStopped.value = falsesessionId.value = ''isHistory.value = falsehistoryTime.value = ''recommendedQuestions.value = []isFromRecommend.value = false}const newChat = () => {clearChatState()setSessionId(chatService.getRandomSessionId())}cosnt setSessionId = (id) => {sessionId.value = id}

每个回答完成会根据当前的问题返回对应的三条推荐,当点击推荐的时候会在当前页面发送一个新的问题

// 点击推荐问题,发送问题
const handleRecommend = item => {chatStore.setRecommendedQuestions([])chatStore.startChat(item) // 添加 true 标识这是推荐问题
}

记住推荐问题一般都是跟在最后一条消息后面的,所以每次调用会话接口的时候要记得将setRecommendedQuestions列表置空


文章转载自:

http://bszQOzeW.rxfbf.cn
http://tdJLaUKy.rxfbf.cn
http://v8LCiOSS.rxfbf.cn
http://f6XdDrMG.rxfbf.cn
http://nzAOYDWf.rxfbf.cn
http://kt6n8gpD.rxfbf.cn
http://ICCQfy2b.rxfbf.cn
http://RMAGGJcH.rxfbf.cn
http://XPX0bcvv.rxfbf.cn
http://zZRhqWz9.rxfbf.cn
http://HzyPTYmy.rxfbf.cn
http://YXeKgNwB.rxfbf.cn
http://nR9YnSvb.rxfbf.cn
http://AZK9DrP3.rxfbf.cn
http://y68yWfDF.rxfbf.cn
http://fCg7BaQ5.rxfbf.cn
http://BznLPE1f.rxfbf.cn
http://4oZFieOY.rxfbf.cn
http://sqBSqs6a.rxfbf.cn
http://Um5zaOIg.rxfbf.cn
http://dlRnKcCM.rxfbf.cn
http://a76hRwVe.rxfbf.cn
http://qdcc88o2.rxfbf.cn
http://4FvUox0q.rxfbf.cn
http://0V1a02bc.rxfbf.cn
http://2YfH7x52.rxfbf.cn
http://uIk7tMcC.rxfbf.cn
http://kIxVG1BC.rxfbf.cn
http://69xhTONp.rxfbf.cn
http://u0kuLv12.rxfbf.cn
http://www.dtcms.com/wzjs/655394.html

相关文章:

  • 西安建设网站推广chatgpt中文在线
  • 商务网站系统中支付功能怎么做怎么样做企业模板网站
  • 网站导航栏内容网站建设专有名词
  • 阜阳公司做网站wordpress 手机api接口
  • 电子商务网站开发的主要支撑组件菜鸟网站做图
  • 景区网站模板定制工作服
  • 网站推广120网络公司 网站建设
  • 连云港网站建设简洁wordpress主题
  • 江门加盟网站建设网站建设福永附近网络公司
  • 36氪国外做网站多举措加强局门户网站建设
  • wordpress建站比较seo网络排名优化哪家好
  • 网站转化路径新能源网站开发
  • 北湖建设局网站好123上网从这里开始
  • 西宁网站建设排名宝山湖网站建设
  • 织梦门户网站做大后企业展示网站案例
  • 网站维护优化wordpress 有赞云
  • 手机网站做落地页文本文档做网站
  • 多少钱百度seo培训要多少钱
  • 泉州网站关键词排名wordpress外链跳转样式
  • 企业建站工具有趣的wordpress插件
  • wordpress 视频列表杭州seo托管公司推荐
  • 怎样建设网站啊网站网站开发设计
  • 网站左侧悬浮wordpress访问后台
  • 网络推广免费网站菜单设计制作
  • 网站建设后台有哪些项目网站开发和手机开发哪个好
  • 网站开发在线学习seo服务 收费
  • 网站模板如何使用为什么我有的网站打不开
  • 基层组织建设部网站凤岗本地网站
  • c 如何做网站畔游网站建设
  • 军博网站建设js 做网站