| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  | <template> | 
					
						
							| 
									
										
										
										
											2022-01-01 09:46:18 +08:00
										 |  |  |   <el-image | 
					
						
							|  |  |  |     :src="`${realSrc}`" | 
					
						
							|  |  |  |     fit="cover" | 
					
						
							|  |  |  |     :style="`width:${realWidth};height:${realHeight};`" | 
					
						
							|  |  |  |     :preview-src-list="realSrcList" | 
					
						
							|  |  |  |   > | 
					
						
							|  |  |  |     <div slot="error" class="image-slot"> | 
					
						
							|  |  |  |       <i class="el-icon-picture-outline"></i> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   </el-image> | 
					
						
							| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2022-01-01 09:46:18 +08:00
										 |  |  | import { isExternal } from "@/utils/validate"; | 
					
						
							| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							| 
									
										
										
										
											2022-01-01 09:46:18 +08:00
										 |  |  |   name: "ImagePreview", | 
					
						
							|  |  |  |   props: { | 
					
						
							|  |  |  |     src: { | 
					
						
							|  |  |  |       type: String, | 
					
						
							|  |  |  |       required: true | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     width: { | 
					
						
							|  |  |  |       type: [Number, String], | 
					
						
							|  |  |  |       default: "" | 
					
						
							| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2022-01-01 09:46:18 +08:00
										 |  |  |     height: { | 
					
						
							|  |  |  |       type: [Number, String], | 
					
						
							|  |  |  |       default: "" | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   computed: { | 
					
						
							|  |  |  |     realSrc() { | 
					
						
							|  |  |  |       let real_src = this.src.split(",")[0]; | 
					
						
							|  |  |  |       if (isExternal(real_src)) { | 
					
						
							|  |  |  |         return real_src; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       return process.env.VUE_APP_BASE_API + real_src; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     realSrcList() { | 
					
						
							|  |  |  |       let real_src_list = this.src.split(","); | 
					
						
							|  |  |  |       let srcList = []; | 
					
						
							|  |  |  |       real_src_list.forEach(item => { | 
					
						
							|  |  |  |         if (isExternal(item)) { | 
					
						
							|  |  |  |           return srcList.push(item); | 
					
						
							| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-01-01 09:46:18 +08:00
										 |  |  |         return srcList.push(process.env.VUE_APP_BASE_API + item); | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |       return srcList; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     realWidth() { | 
					
						
							|  |  |  |       return typeof this.width == "string" ? this.width : `${this.width}px`; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     realHeight() { | 
					
						
							|  |  |  |       return typeof this.height == "string" ? this.height : `${this.height}px`; | 
					
						
							| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-01-01 09:46:18 +08:00
										 |  |  |   }, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | .el-image { | 
					
						
							| 
									
										
										
										
											2022-01-01 09:46:18 +08:00
										 |  |  |   border-radius: 5px; | 
					
						
							|  |  |  |   background-color: #ebeef5; | 
					
						
							|  |  |  |   box-shadow: 0 0 5px 1px #ccc; | 
					
						
							|  |  |  |   ::v-deep .el-image__inner { | 
					
						
							|  |  |  |     transition: all 0.3s; | 
					
						
							|  |  |  |     cursor: pointer; | 
					
						
							|  |  |  |     &:hover { | 
					
						
							|  |  |  |       transform: scale(1.2); | 
					
						
							| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-01-01 09:46:18 +08:00
										 |  |  |   } | 
					
						
							|  |  |  |   ::v-deep .image-slot { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     justify-content: center; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     width: 100%; | 
					
						
							|  |  |  |     height: 100%; | 
					
						
							|  |  |  |     color: #909399; | 
					
						
							|  |  |  |     font-size: 30px; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2021-12-18 12:23:59 +08:00
										 |  |  | } | 
					
						
							|  |  |  | </style> |