| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <div class="component-upload-image"> | 
					
						
							|  |  |  |     <el-upload | 
					
						
							| 
									
										
										
										
											2022-02-25 09:08:56 +08:00
										 |  |  |       multiple | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |       :action="uploadImgUrl" | 
					
						
							|  |  |  |       list-type="picture-card" | 
					
						
							|  |  |  |       :on-success="handleUploadSuccess" | 
					
						
							|  |  |  |       :before-upload="handleBeforeUpload" | 
					
						
							| 
									
										
										
										
											2025-04-18 12:55:58 +08:00
										 |  |  |       :data="data" | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       :limit="limit" | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |       :on-error="handleUploadError" | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       :on-exceed="handleExceed" | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |       ref="imageUpload" | 
					
						
							|  |  |  |       :on-remove="handleDelete" | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       :show-file-list="true" | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |       :headers="headers" | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       :file-list="fileList" | 
					
						
							|  |  |  |       :on-preview="handlePictureCardPreview" | 
					
						
							|  |  |  |       :class="{hide: this.fileList.length >= this.limit}" | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |     > | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       <i class="el-icon-plus"></i> | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |     </el-upload> | 
					
						
							| 
									
										
										
										
											2023-11-29 12:38:45 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     <!-- 上传提示 --> | 
					
						
							|  |  |  |     <div class="el-upload__tip" slot="tip" v-if="showTip"> | 
					
						
							|  |  |  |       请上传 | 
					
						
							|  |  |  |       <template v-if="fileSize"> 大小不超过 <b style="color: #f56c6c">{{ fileSize }}MB</b> </template> | 
					
						
							|  |  |  |       <template v-if="fileType"> 格式为 <b style="color: #f56c6c">{{ fileType.join("/") }}</b> </template> | 
					
						
							|  |  |  |       的文件 | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <el-dialog | 
					
						
							|  |  |  |       :visible.sync="dialogVisible" | 
					
						
							|  |  |  |       title="预览" | 
					
						
							|  |  |  |       width="800" | 
					
						
							|  |  |  |       append-to-body | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       <img | 
					
						
							|  |  |  |         :src="dialogImageUrl" | 
					
						
							|  |  |  |         style="display: block; max-width: 100%; margin: 0 auto" | 
					
						
							|  |  |  |       /> | 
					
						
							| 
									
										
										
										
											2021-01-05 20:33:41 +08:00
										 |  |  |     </el-dialog> | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  | import { getToken } from "@/utils/auth" | 
					
						
							|  |  |  | import { isExternal } from "@/utils/validate" | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |   props: { | 
					
						
							|  |  |  |     value: [String, Object, Array], | 
					
						
							| 
									
										
										
										
											2025-04-18 12:55:58 +08:00
										 |  |  |     // 上传接口地址
 | 
					
						
							|  |  |  |     action: { | 
					
						
							|  |  |  |       type: String, | 
					
						
							|  |  |  |       default: "/common/upload" | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 上传携带的参数
 | 
					
						
							|  |  |  |     data: { | 
					
						
							|  |  |  |       type: Object | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     // 图片数量限制
 | 
					
						
							|  |  |  |     limit: { | 
					
						
							|  |  |  |       type: Number, | 
					
						
							|  |  |  |       default: 5, | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 大小限制(MB)
 | 
					
						
							|  |  |  |     fileSize: { | 
					
						
							|  |  |  |        type: Number, | 
					
						
							|  |  |  |       default: 5, | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 文件类型, 例如['png', 'jpg', 'jpeg']
 | 
					
						
							|  |  |  |     fileType: { | 
					
						
							|  |  |  |       type: Array, | 
					
						
							|  |  |  |       default: () => ["png", "jpg", "jpeg"], | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 是否显示提示
 | 
					
						
							|  |  |  |     isShowTip: { | 
					
						
							|  |  |  |       type: Boolean, | 
					
						
							|  |  |  |       default: true | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							| 
									
										
										
										
											2022-02-25 09:08:56 +08:00
										 |  |  |       number: 0, | 
					
						
							|  |  |  |       uploadList: [], | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       dialogImageUrl: "", | 
					
						
							| 
									
										
										
										
											2021-01-05 20:33:41 +08:00
										 |  |  |       dialogVisible: false, | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       hideUpload: false, | 
					
						
							|  |  |  |       baseUrl: process.env.VUE_APP_BASE_API, | 
					
						
							| 
									
										
										
										
											2025-04-18 12:55:58 +08:00
										 |  |  |       uploadImgUrl: process.env.VUE_APP_BASE_API + this.action, // 上传的图片服务器地址
 | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |       headers: { | 
					
						
							|  |  |  |         Authorization: "Bearer " + getToken(), | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       fileList: [] | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |   }, | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |   watch: { | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |     value: { | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       handler(val) { | 
					
						
							|  |  |  |         if (val) { | 
					
						
							|  |  |  |           // 首先将值转为数组
 | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |           const list = Array.isArray(val) ? val : this.value.split(',') | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |           // 然后将数组转为对象数组
 | 
					
						
							|  |  |  |           this.fileList = list.map(item => { | 
					
						
							|  |  |  |             if (typeof item === "string") { | 
					
						
							| 
									
										
										
										
											2024-10-21 03:39:18 +00:00
										 |  |  |               if (item.indexOf(this.baseUrl) === -1 && !isExternal(item)) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |                   item = { name: this.baseUrl + item, url: this.baseUrl + item } | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |               } else { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |                   item = { name: item, url: item } | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |             return item | 
					
						
							|  |  |  |           }) | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |           this.fileList = [] | 
					
						
							|  |  |  |           return [] | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       deep: true, | 
					
						
							|  |  |  |       immediate: true | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   computed: { | 
					
						
							|  |  |  |     // 是否显示提示
 | 
					
						
							|  |  |  |     showTip() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       return this.isShowTip && (this.fileType || this.fileSize) | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     // 上传前loading加载
 | 
					
						
							|  |  |  |     handleBeforeUpload(file) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       let isImg = false | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       if (this.fileType.length) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         let fileExtension = "" | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |         if (file.name.lastIndexOf(".") > -1) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |           fileExtension = file.name.slice(file.name.lastIndexOf(".") + 1) | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |         isImg = this.fileType.some(type => { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |           if (file.type.indexOf(type) > -1) return true | 
					
						
							|  |  |  |           if (fileExtension && fileExtension.indexOf(type) > -1) return true | 
					
						
							|  |  |  |           return false | 
					
						
							|  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         isImg = file.type.indexOf("image") > -1 | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (!isImg) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         this.$modal.msgError(`文件格式不正确,请上传${this.fileType.join("/")}图片格式文件!`) | 
					
						
							|  |  |  |         return false | 
					
						
							| 
									
										
										
										
											2024-11-05 12:49:40 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |       if (file.name.includes(',')) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         this.$modal.msgError('文件名不正确,不能包含英文逗号!') | 
					
						
							|  |  |  |         return false | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |       if (this.fileSize) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         const isLt = file.size / 1024 / 1024 < this.fileSize | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |         if (!isLt) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |           this.$modal.msgError(`上传头像图片大小不能超过 ${this.fileSize} MB!`) | 
					
						
							|  |  |  |           return false | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       this.$modal.loading("正在上传图片,请稍候...") | 
					
						
							|  |  |  |       this.number++ | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     // 文件个数超出
 | 
					
						
							|  |  |  |     handleExceed() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       this.$modal.msgError(`上传文件数量不能超过 ${this.limit} 个!`) | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |     // 上传成功回调
 | 
					
						
							|  |  |  |     handleUploadSuccess(res, file) { | 
					
						
							|  |  |  |       if (res.code === 200) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         this.uploadList.push({ name: res.fileName, url: res.fileName }) | 
					
						
							|  |  |  |         this.uploadedSuccessfully() | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         this.number-- | 
					
						
							|  |  |  |         this.$modal.closeLoading() | 
					
						
							|  |  |  |         this.$modal.msgError(res.msg) | 
					
						
							|  |  |  |         this.$refs.imageUpload.handleRemove(file) | 
					
						
							|  |  |  |         this.uploadedSuccessfully() | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 删除图片
 | 
					
						
							|  |  |  |     handleDelete(file) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       const findex = this.fileList.map(f => f.name).indexOf(file.name) | 
					
						
							| 
									
										
										
										
											2023-11-30 09:37:36 +08:00
										 |  |  |       if (findex > -1) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         this.fileList.splice(findex, 1) | 
					
						
							|  |  |  |         this.$emit("input", this.listToString(this.fileList)) | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     // 上传失败
 | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |     handleUploadError() { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       this.$modal.msgError("上传图片失败,请重试") | 
					
						
							|  |  |  |       this.$modal.closeLoading() | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |     // 上传结束处理
 | 
					
						
							|  |  |  |     uploadedSuccessfully() { | 
					
						
							|  |  |  |       if (this.number > 0 && this.uploadList.length === this.number) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |         this.fileList = this.fileList.concat(this.uploadList) | 
					
						
							|  |  |  |         this.uploadList = [] | 
					
						
							|  |  |  |         this.number = 0 | 
					
						
							|  |  |  |         this.$emit("input", this.listToString(this.fileList)) | 
					
						
							|  |  |  |         this.$modal.closeLoading() | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     // 预览
 | 
					
						
							|  |  |  |     handlePictureCardPreview(file) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       this.dialogImageUrl = file.url | 
					
						
							|  |  |  |       this.dialogVisible = true | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     // 对象转成指定字符串分隔
 | 
					
						
							|  |  |  |     listToString(list, separator) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       let strs = "" | 
					
						
							|  |  |  |       separator = separator || "," | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       for (let i in list) { | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |         if (list[i].url) { | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |           strs += list[i].url.replace(this.baseUrl, "") + separator | 
					
						
							| 
									
										
										
										
											2022-08-24 11:18:52 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  |       return strs != '' ? strs.substr(0, strs.length - 1) : '' | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2025-04-27 10:05:51 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2020-11-16 15:52:58 +08:00
										 |  |  | </script> | 
					
						
							|  |  |  | <style scoped lang="scss"> | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  | // .el-upload--picture-card 控制加号部分
 | 
					
						
							|  |  |  | ::v-deep.hide .el-upload--picture-card { | 
					
						
							|  |  |  |     display: none; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // 去掉动画效果
 | 
					
						
							|  |  |  | ::v-deep .el-list-enter-active, | 
					
						
							|  |  |  | ::v-deep .el-list-leave-active { | 
					
						
							|  |  |  |     transition: all 0s; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::v-deep .el-list-enter, .el-list-leave-active { | 
					
						
							| 
									
										
										
										
											2023-11-29 12:38:45 +08:00
										 |  |  |   opacity: 0; | 
					
						
							|  |  |  |   transform: translateY(0); | 
					
						
							| 
									
										
										
										
											2021-01-05 16:13:22 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2021-07-08 19:17:09 +08:00
										 |  |  | </style> | 
					
						
							|  |  |  | 
 |