13. 开发个人资料功能
学生管理上传头像
<el-upload action="http://localhost:9090/files/upload" list-type="picture" :on-success="handleImgUploadSuccess">
<el-button type="primary">上传头像</el-button>
</el-upload>
const handleImgUploadSuccess = (res) => {
data.form.avatar = res.data
}
在表格里显示图片
<el-table-column prop="avatar" label="头像">
<template #default="scope">
<el-image v-if="scope.row.avatar" :src="scope.row.avatar" :preview-src-list="[scope.row.avatar]" style="width: 40px; height: 40px; border-radius: 5px"></el-image>
</template>
</el-table-column>
个人资料
<template>
<div>
<div class="card" style="width: 50%; padding: 40px">
<el-form :model="data.form" ref="formRef" label-width="100px" label-position="right"
style="padding-right: 40px">
<el-form-item label="学生头像">
<el-upload class="avatar-uploader" action="http://localhost:9090/files/upload" :show-file-list="false"
:on-success="handleImgUploadSuccess">
<img v-if="data.form.avatar" :src="data.form.avatar" class="avatar">
<el-icon v-else class="avatar-uploader-icon"><Plus /></el-icon>
</el-upload>
</el-form-item>
<el-form-item label="学生账号" prop="username">
<el-input v-model="data.form.username" autocomplete="off" disabled />
</el-form-item>
<el-form-item label="学生密码" prop="password">
<el-input show-password v-model="data.form.password" autocomplete="off"/>
</el-form-item>
<el-form-item label="学生名称">
<el-input v-model="data.form.name" autocomplete="off"/>
</el-form-item>
<el-form-item label="手机号">
<el-input v-model="data.form.phone" autocomplete="off"/>
</el-form-item>
<el-form-item label="邮箱">
<el-input v-model="data.form.email" autocomplete="off"/>
</el-form-item>
<el-form-item label="性别">
<el-radio-group v-model="data.form.sex">
<el-radio label="男"></el-radio>
<el-radio label="女"></el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="生日">
<el-date-picker style="width: 100%" format="YYYY-MM-DD" value-format="YYYY-MM-DD"
v-model="data.form.birth"></el-date-picker>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="update">保 存</el-button>
</el-form-item>
</el-form>
</div>
</div>
</template>
<script setup>
import {reactive} from "vue";
import request from "@/utils/request";
import {ElMessage} from "element-plus";
import router from "@/router";
import {Plus} from "@element-plus/icons-vue"
const data = reactive({
form: JSON.parse(localStorage.getItem('student-user') || "{}")
})
const handleImgUploadSuccess = (res) => {
data.form.avatar = res.data
}
const update = () => {
request.put('/student/update', data.form).then(res => {
if (res.code === '200') {
ElMessage.success("操作成功")
router.push('/login')
} else {
ElMessage.error(res.msg)
}
})
}
</script>
<style>
.avatar-uploader .el-upload {
border: 1px dashed #d9d9d9;
border-radius: 6px;
cursor: pointer;
position: relative;
overflow: hidden;
}
.avatar-uploader .el-upload:hover {
border-color: #409EFF;
}
.avatar-uploader-icon {
font-size: 28px;
color: #8c939d;
width: 100px;
height: 100px;
line-height: 100px;
text-align: center;
}
.avatar {
width: 100px;
height: 100px;
display: block;
}
</style>
Manager 改了点东西

