basic.vue 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. <template>
  2. <el-upload
  3. v-model:file-list="fileList"
  4. class="upload-demo"
  5. action="https://run.mocky.io/v3/9d059bf9-4660-45f2-925d-ce80ad6c4d15"
  6. multiple
  7. :on-preview="handlePreview"
  8. :on-remove="handleRemove"
  9. :before-remove="beforeRemove"
  10. :limit="3"
  11. :on-exceed="handleExceed"
  12. >
  13. <el-button type="primary">Click to upload</el-button>
  14. <template #tip>
  15. <div class="el-upload__tip">jpg/png files with a size less than 500KB.</div>
  16. </template>
  17. </el-upload>
  18. </template>
  19. <script lang="ts" setup>
  20. import { ref } from 'vue'
  21. import { ElMessage, ElMessageBox } from 'element-plus'
  22. import type { UploadProps, UploadUserFile } from 'element-plus'
  23. const fileList = ref<UploadUserFile[]>([
  24. {
  25. name: 'element-plus-logo.svg',
  26. url: 'https://element-plus.org/images/element-plus-logo.svg',
  27. },
  28. {
  29. name: 'element-plus-logo2.svg',
  30. url: 'https://element-plus.org/images/element-plus-logo.svg',
  31. },
  32. ])
  33. const handleRemove: UploadProps['onRemove'] = (file, uploadFiles) => {
  34. console.log(file, uploadFiles)
  35. }
  36. const handlePreview: UploadProps['onPreview'] = uploadFile => {
  37. console.log(uploadFile)
  38. }
  39. const handleExceed: UploadProps['onExceed'] = (files, uploadFiles) => {
  40. ElMessage.warning(`The limit is 3, you selected ${files.length} files this time, add up to ${files.length + uploadFiles.length} totally`)
  41. }
  42. const beforeRemove: UploadProps['beforeRemove'] = (uploadFile, uploadFiles) => {
  43. return ElMessageBox.confirm(`Cancel the transfert of ${uploadFile.name} ?`).then(
  44. () => true,
  45. () => false
  46. )
  47. }
  48. </script>