AddChatDetail.vue 2.1 KB
Newer Older
1
<template>
2
	<div>
3
		<el-button type="primary" plain size="medium" @click="goBack">后退</el-button>
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
		<h4 class="text-center">新增ChatGpt问答</h4>
		<el-container class="container">
			<el-form ref="form" :model="form" label-width="80px">
				<el-form-item label="问题">
					<el-input v-model="form.question"></el-input>
				</el-form-item>
				<el-form-item label="答案">
					<el-input type="textarea" v-model="form.response"></el-input>
				</el-form-item>
				<el-form-item>
					<el-button type="primary" @click="onSubmit">立即创建</el-button>
					<el-button @click="clearContent">取消</el-button>
				</el-form-item>
			</el-form>
		</el-container>
	</div>
20 21 22
</template>
<script>
// 导入 axios 请求库
23
import axios from 'axios'
24
export default {
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
	name: 'AddChatDetail',
	data() {
		return {
			form: {
				question: '',
				response: '',
			},
		}
	},
	methods: {
		clearContent() {
			this.form.question = ''
			this.form.response = ''
		},
		async onSubmit() {
			const data = {
				question: this.form.question,
				response: this.form.response,
			}
			axios
45
				.post('http://localhost:8080/chatbot', data)
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
				.then((response) => {
					// 只要请求回来的数据,在页面渲染期间要用到,则必须转存到 data 中
					if (response.data.code === 200) {
						this.$message.success({
							message: '问题和答案新增成功',
							duration: 1000,
						})
						this.goBack()
					}
				})
				.catch((error) => {
					// 处理错误
					this.$message.error('系统异常')
				})
		},
		goBack() {
			// 传递参数到前一个页面
			const params = {
				// 参数名: 参数值
				back: 'back',
				add: 'add',
			}
			// 使用 $router.push() 导航到前一个页面
			this.$router.push({
				path: '/home/chat', // 前一个页面的路径
				query: params, // 参数对象
			})
		},
	},
75
}
76 77 78 79
</script>

<style lang="less" scoped>
.container {
80 81 82 83
	display: flex;
	justify-content: center;
	align-items: center;
	height: 30vh; /* 如果希望 `el-container` 在整个视口居中,可以使用 height: 100vh; 来设置容器的高度 */
84
}
85
</style>