basic.vue 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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">
  16. jpg/png files with a size less than 500KB.
  17. </div>
  18. </template>
  19. </el-upload>
  20. </template>
  21. <script lang="ts" setup>
  22. import { ref } from 'vue'
  23. import { ElMessage, ElMessageBox } from 'element-plus'
  24. import type { UploadProps, UploadUserFile } from 'element-plus'
  25. const fileList = ref<UploadUserFile[]>([
  26. {
  27. name: 'element-plus-logo.svg',
  28. url: 'https://element-plus.org/images/element-plus-logo.svg',
  29. },
  30. {
  31. name: 'element-plus-logo2.svg',
  32. url: 'https://element-plus.org/images/element-plus-logo.svg',
  33. },
  34. ])
  35. const handleRemove: UploadProps['onRemove'] = (file, uploadFiles) => {
  36. console.log(file, uploadFiles)
  37. }
  38. const handlePreview: UploadProps['onPreview'] = (uploadFile) => {
  39. console.log(uploadFile)
  40. }
  41. const handleExceed: UploadProps['onExceed'] = (files, uploadFiles) => {
  42. ElMessage.warning(
  43. `The limit is 3, you selected ${files.length} files this time, add up to ${
  44. files.length + uploadFiles.length
  45. } totally`
  46. )
  47. }
  48. const beforeRemove: UploadProps['beforeRemove'] = (uploadFile, uploadFiles) => {
  49. return ElMessageBox.confirm(
  50. `Cancel the transfert of ${uploadFile.name} ?`
  51. ).then(
  52. () => true,
  53. () => false
  54. )
  55. }
  56. </script>