web/src/components/UpLoad.vue

68 lines
1.6 KiB
Vue

<template>
<el-upload
class="avatar-uploader"
:action="url"
:show-file-list="false"
:on-success="handleSuccess"
:before-upload="beforeUpload"
:on-error="handleError"
>
<img v-if="imageUrl" :src="imageUrl" class="avatar" alt=""/>
<el-icon v-else><Plus /></el-icon>
</el-upload>
</template>
<script setup lang="ts">
import {ElMessage} from 'element-plus'
import {Plus} from '@element-plus/icons-vue'
import {defineModel,ref} from 'vue'
import {loadConfig} from "@/utils/config.ts";
const url = defineModel()
const imageUrl = ref<any>()
const getImageUrl = (url: any) => {
loadConfig().then(res=>{
imageUrl.value = res.base_url +'file/getImage/'+ url
})
}
const emit = defineEmits(['uploadSuccess'])
const handleSuccess = (response:any) => {
ElMessage.success('文件上传成功!'); // 添加成功提示
getImageUrl(response.data)
emit('uploadSuccess',response.data)
}
const handleError = () => {
ElMessage.error('文件上传失败');
}
const beforeUpload = (file:any) => {
const isLt2M = file.size / 1024 / 1024 < 2;
if (!isLt2M) {
ElMessage.error('上传文件大小不能超过 2MB!');
}
return isLt2M;
}
defineExpose({getImageUrl})
</script>
<style scoped>
.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: 178px;
}
.avatar {
width: 178px;
height: 178px;
display: block;
}
</style>