首页 > 其他分享 >AI大语言模型LLM学习-基于Vue3的AI问答页面

AI大语言模型LLM学习-基于Vue3的AI问答页面

时间:2024-09-08 11:49:42浏览次数:20  
标签:vue LLM form AI chat Vue3 msg import

系列文章


1. AI大语言模型LLM学习-入门篇
2. AI大语言模型LLM学习-Token及流式响应
3. AI大语言模型LLM学习-WebAPI搭建


前言


在上一篇博文中,我们使用Flask这一Web框架结合LLM模型实现了后端流式WebAPI接口,本篇将基于Vue3实现AI问答页面,本人习惯使用HBuilder进行前端页面的开发,当然各位网友可以选择自己喜欢的前端开发IDE,比如VS Code。


一、设计思路

打开一个主流的AI对话页面,比如我注册的是阿里的通义千问
可以看到页面的效果如图所示:
在这里插入图片描述
根据页面效果,可以大致把内容可以分为如下3部分:

  1. 标题
  2. 问答对话,右侧为用户输入的问题,左侧为AI的回答;此部分需要自定义组件,左右布局,可复用,采用循环实现
  3. 底部输入区域,包含输入框及发送按钮

二、编码实现


1.项目新建

在这里插入图片描述

2.项目结构

在这里插入图片描述

3.代码部分

3.1 安装并引入element-plus

npm install element-plus --save

关于element-plus相关组件的使用,参考element-plus官网

  • mian.js配置
import { createApp } from 'vue'
import App from './App.vue'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'

const app = createApp(App)
//引入element-plus
app.use(ElementPlus)
app.mount('#app')

3.2 api接口进行代理

注意:api接口不能直接在html页面中进行调用,存在跨域访问的问题,需要在vite.config.js添加代
理配置。
生产环境部署时可以采用nginx对api接口进行反向代理解决跨域问题。

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
  server:{
	  proxy:{
		  '/chat':{
				   target:"http://127.0.0.1:2024/",
				   changeOrigin: true,
		  },
	  }
  }
})

3.3对话组件

chat.vue代码如下:

<script setup>
import { ref } from 'vue'
defineProps({
  msg: Object
})
const count = ref(0)
</script>
<template>
<div class="chat">
	<!--问题-->
	<div style="text-align: right;">
		<div class="el-card chat-right" >
			{{msg.question}}
		</div>
	</div>
	<!--AI回答-->
	<div style="text-align: left;">
		<div class="el-card chat-left">
			{{msg.answer}}
		</div>
	</div>
</div>
</template>
<style scoped>
.chat{
	max-width: 1000px;
	margin: 0 auto;
	padding-top: 10px;
	padding-bottom: 10px;
}
.ai-img
{
	height: 36px;
	width: 36px;
}
.chat-left
{
	background-color: #f5f6f7!important;
	display: inline-block;
	box-sizing: border-box;
	width: auto;
	text-align: left;
	border-radius: 12px;
	line-height: 24px;
	max-width: 100%;
	padding: 12px 16px;
	white-space: pre-wrap;
	
}
.chat-right
{
	background-color: #e0dfff;
	display: inline-block;
	box-sizing: border-box;
	width: auto;
	color: #3f3f3f;
	border-radius: 12px;
	line-height: 24px;
	max-width: 100%;
	padding: 12px 16px;
	white-space: pre-wrap;
}
</style>

3.4主体页面

代码如下:

<template>
	<div class="common-layout">
	    <el-container style="height:100%;width:100%;margin: 0 auto;">
			 <el-header style="height: 50px; width: 100% ;backgroundColor:rgba(0,102,255,.06)">
				<p class="centered-text">AI-历史人物</p>
			 </el-header>
			 <el-main id="chat">
				  <chat v-for="item in form.msgList" :msg=item></chat>
			 </el-main>
			 <el-row style="margin: 0 auto;padding-left: 20px;padding-right: 20px;">
				 <div style="width: 100%;">
					<el-input style="float: left;width: 90%;" @keyup.enter="sendMsg" v-model="form.input"></el-input>
					<el-button @click="sendMsg" style="float: right; height: 42px;line-height: 42px;" >发送</el-button>
				 </div>
				 <div style="margin: 0 auto;">
					<p style="color: red;font-size: 11px;">
					 服务生成的所有内容均由人工智能模型生成,其生成内容的准确性和完整性无法保证,不代表我们的态度或观点
					</p>
				 </div>
			 </el-row>
		</el-container>
	</div>
</template>
<script setup>
import { reactive,nextTick, ref } from 'vue'
import chat from './components/chat.vue'
	const form = reactive({
	  input: '',//输入
	  msgList:[] //消息列表
	});
	
	async function sendMsg()
	{
		var keyword=form.input;
		if(form.input.length>0)
		{
			var msg={
				question:keyword,
				answer:"AI生成中..."
			};
			form.msgList.push(msg);
			
			form.input="";
			setScrollToBottom();
			const response=await fetch('/chat',{
				method:"post",
				headers:{'Content-Type':'application/json'},
				body:JSON.stringify({
					question:keyword
				})
			});
			if (!response.ok) {
				throw new Error(`HTTP error! status: ${response.status}`);
			}
			
			const reader = response.body.getReader();
			let decoder = new TextDecoder();
			let resultData = '';
			
			var str="";
			
			msg={
				question:keyword,
				answer:str
			};
			form.msgList.pop();
			form.msgList.push(msg);
			while (true) {
				const { done, value } = await reader.read();
				if (done) break;
				resultData = decoder.decode(value);
				console.log(resultData);
				str+=resultData;
				msg={
					question:keyword,
					answer:str
				};
				form.msgList.pop();
				form.msgList.push(msg);
				setScrollToBottom();
			}
		}
		
	}
	
	/*内容显示过多时自动滑动*/
	async function setScrollToBottom() {
	  await nextTick()
	  let chat = document.querySelector("#chat")
	  chat.scrollTop = chat.scrollHeight
	}
	
</script>
<style>
html,body{
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	border: 0;
}
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  height:100%;min-width: 380px;
}
.common-layout{
	height: 100%;
}
#chat{
	height: calc(100vh - 150px);
}
.el-input{
	height: 45px;
	border-radius: 12px;
	box-sizing: border-box;
}
</style>

运行效果展示


在这里插入图片描述

标签:vue,LLM,form,AI,chat,Vue3,msg,import
From: https://blog.csdn.net/fengqiuhuang123/article/details/141997880

相关文章

  • 【Git】在JetBrains系列的IDE中使用Git(一)
    【Git】在JetBrains系列的IDE中使用Git(一)文章目录【Git】在JetBrains系列的IDE中使用Git(一)1.将文件添加到git仓库的暂存区2.将文件提交到git仓库的本地仓库3.分支4.总结我们利用我上一个博文【Ruby】Web框架rubyonrails初识(MVC架构初理解)中创建的项目作为......
  • Datawhale X李宏毅苹果书AI夏令营 第五期 深度学习入门 task3
      本次任务主要是了解模型在训练集或测试集上损失较大时的几大原因,了解改进的方向一、模型偏差   模型过于简单,未知参数函数的所有可能性的集合太小,让损失变低的函数不在模型可以描述的范围内;或者是模型的灵活性不够。这个时候重新设计一个模型,给模型更大的灵活性,将......
  • AIGC月刊 | 大模型/多模态/文生图/AI视频最新技术进展(2024.8月第四期)|【魔方AI新视界
    〔更多精彩AI内容,尽在 「魔方AI空间」 公众号,引领AIGC科技时代〕关注了解更多AI内容本文作者:猫先生AIGCmagic社区知识库(免费访问)原文地址:AIGC月刊|大模型/多模态/文生图/AI视频最新技术进展(2024.8月第四期)【魔方AI新视界】写在前面【魔方AI新视界】专栏致......
  • 【AIGC】AI编程工具合集及其特点介绍
    ......
  • AI虚拟主播Vtuber研发(N卡版本)-Ai吟美-人工智能虚拟主播-一站式人工智能直播平台【教
    开发者:WinloneB站频道:程序猿的退休生活Q群:27831318版本:1.8.1 =========================系统:Windows11专业版显卡1:2080TI22g魔改耕升显卡2: 2080TI22g魔改丽台显卡3: 2080TI22g魔改七彩虹CUDATooklkit:12.3CUDAdriverapi:12.3=========================......
  • 大模型API实战-console.bce.baidu.com/qianfan/
    百度千帆大模型平台API调用实战需要注册并实名制,然后到模型服务-->模型推理,选择可以免费开通的模型开通(其他都是收费的有坑)ACCESS_KEY、SECRET_KEY和AK、SK的获取ACCESS_KEY、SECRET_KEYpython调用#安装包(Python>=3.7):pipinstallqianfanimportosimportqianfan......
  • main() 方法
    根据Java语言规范,main()方法必须被申明为public。在Java1.4及之后的版本中,Java解释器强制要求main()方法必须是public。Java语言规范(JavaLanguageandVirtualMachineSpecifications)public:被JVM调用,访问权限足够大。static:被JVM调用,不用创建对象,直接类名访......
  • 使用亚马逊Bedrock的Stable Diffusion XL模型实现文本到图像生成:探索AI的无限创意
    引言什么是AmazonBedrock?AmazonBedrock是亚马逊云服务(AWS)推出的一项旗舰服务,旨在推动生成式人工智能(AI)在各行业的广泛应用。它的核心功能是提供由顶尖AI公司(如AI21Labs、Anthropic、Cohere、Meta、MistralAI、StabilityAI以及亚马逊自身)开发的多种基础模型(FoundationMo......