custom-thumbnail.vue 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. <template>
  2. <el-upload action="#" list-type="picture-card" :auto-upload="false">
  3. <el-icon><Plus /></el-icon>
  4. <template #file="{ file }">
  5. <div>
  6. <img class="el-upload-list__item-thumbnail" :src="file.url" alt="" />
  7. <span class="el-upload-list__item-actions">
  8. <span class="el-upload-list__item-preview" @click="handlePictureCardPreview(file)">
  9. <el-icon><zoom-in /></el-icon>
  10. </span>
  11. <span v-if="!disabled" class="el-upload-list__item-delete" @click="handleDownload(file)">
  12. <el-icon><Download /></el-icon>
  13. </span>
  14. <span v-if="!disabled" class="el-upload-list__item-delete" @click="handleRemove(file)">
  15. <el-icon><Delete /></el-icon>
  16. </span>
  17. </span>
  18. </div>
  19. </template>
  20. </el-upload>
  21. <el-dialog v-model="dialogVisible">
  22. <img w-full :src="dialogImageUrl" alt="Preview Image" />
  23. </el-dialog>
  24. </template>
  25. <script lang="ts" setup>
  26. import { ref } from 'vue'
  27. import { Delete, Download, Plus, ZoomIn } from '@element-plus/icons-vue'
  28. import type { UploadFile } from 'element-plus'
  29. const dialogImageUrl = ref('')
  30. const dialogVisible = ref(false)
  31. const disabled = ref(false)
  32. const handleRemove = (file: UploadFile) => {
  33. console.log(file)
  34. }
  35. const handlePictureCardPreview = (file: UploadFile) => {
  36. dialogImageUrl.value = file.url!
  37. dialogVisible.value = true
  38. }
  39. const handleDownload = (file: UploadFile) => {
  40. console.log(file)
  41. }
  42. </script>