<template>
|
<div>
|
<el-upload
|
class="upload-demo"
|
:accept="uploadData.fileType"
|
:action="uploadImgUrl"
|
:limit="this.fileLength"
|
:on-exceed="handleExceed"
|
:on-success="handleFileSuccess"
|
:on-error="uploadError"
|
:before-upload="beforeFileUpload"
|
:file-list="fileList">
|
<el-button size="small" type="primary">点击上传</el-button>
|
<div slot="tip" class="el-upload__tip" >
|
只能上传{{ this.fileLength }}个文件,
|
{{uploadData.fileType?('只支持上传【'+uploadData.fileType+'】类型文件'):''}}
|
文件大小不能超过30MB,
|
数量超过请删除已传附件重新上传
|
</div>
|
</el-upload>
|
</div>
|
|
</template>
|
|
<script>
|
export default {
|
props: {
|
file: {
|
type: Object,
|
default: () => {}
|
},
|
tipsLabel: '',
|
customStyle: {
|
type: String,
|
default: 'width: 190px; height: 190px;'
|
},
|
fileLength:{
|
type: Number,
|
default: () => 1
|
},
|
uploadData: Object
|
},
|
data() {
|
return {
|
fileList: [],
|
uploadImgUrl: process.env.VUE_APP_API_PREFIX + '/visitsAdmin/cloudService/public/upload?folder='+this.uploadData.folder
|
}
|
},
|
|
methods: {
|
// 上传图片
|
handleExceed(){
|
if(this.fileList && this.fileList.length >= this.fileLength){
|
this.$message.error('只允许上传【'+this.fileLength+'个附件】')
|
}
|
},
|
handleFileSuccess(res, file) {
|
if (res.code == 200) {
|
let { data } = res
|
this.fileList = [{name: data.originname, url: data.url }]
|
this.$message.success('上传成功')
|
this.$emit('uploadSuccess', { fileurl: data.imgaddr, fileurlFull: data.url, name: data.originname,fileSize:data.fileSize })
|
} else {
|
this.$message.error('上传失败')
|
}
|
this.$emit('uploadEnd')
|
},
|
uploadError() {
|
this.$message.error('上传失败')
|
this.$emit('uploadEnd')
|
},
|
//
|
beforeFileUpload(file) {
|
if(this.fileList && this.fileList.length >= this.fileLength){
|
this.$message.error('只允许上传【'+this.fileLength+'个文件】')
|
return false;
|
}
|
const isLt2M = file.size / 1024 / 1024 <= 30; // 检查文件大小是否小于30MB
|
if (!isLt2M) {
|
this.$message.error('上传文件大小不能超过 30MB!');
|
return false; // 不允许上传超过指定大小的文件
|
}
|
this.$emit('uploadBegin')
|
return true
|
}
|
}
|
}
|
</script>
|
|
<style lang="scss" scoped>
|
$image-width: 100px;
|
$image-height: 30px;
|
.avatar-uploader {
|
width: 100px;
|
height: $image-width;
|
}
|
::v-deep .el-upload {
|
border: 1px dashed #d9d9d9;
|
border-radius: 6px;
|
cursor: pointer;
|
position: relative;
|
width: $image-width;
|
height: $image-height;
|
overflow: hidden;
|
}
|
.avatar-uploader .el-upload:hover {
|
border-color: #409EFF;
|
}
|
.avatar-uploader-icon {
|
line-height: 90px;
|
font-size: 28px;
|
color: #8c939d;
|
width: $image-width;
|
height: $image-height;
|
text-align: center;
|
}
|
.avatar {
|
width: $image-width;
|
height: $image-height;
|
display: block;
|
}
|
.tips-style {
|
height: 13px;
|
font-size: 13px;
|
font-weight: 400;
|
color: #999999;
|
line-height: 13px;
|
}
|
</style>
|
<style lang="scss" scoped>
|
::v-deep .el-upload--picture-card{
|
width: 90px !important;
|
height: 90px !important;
|
}
|
|
.icon {
|
-webkit-transform: translate(-50%,-50%);
|
-ms-transform: translate(-50%,-50%);
|
transform: translate(0%, -85%);
|
}
|
::v-deep .el-upload-list__item {
|
width: 500px !important;
|
height: 30px !important;
|
}
|
</style>
|