form.vue 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <template>
  2. <div class="form">
  3. <el-form ref="form" :model="form" label-width="100px" label-position="left">
  4. <el-form-item label="上传数据源">
  5. <el-radio-group v-model="form.dataSource">
  6. <el-radio-button label="1">本地</el-radio-button>
  7. <el-radio-button label="2">阿里云OSS</el-radio-button>
  8. <el-radio-button label="3">七牛云</el-radio-button>
  9. <el-radio-button label="4">腾讯云COS</el-radio-button>
  10. </el-radio-group>
  11. </el-form-item>
  12. </el-form>
  13. <el-tabs v-model="activeTab">
  14. <el-tab-pane label="文件" name="1">
  15. <el-upload
  16. ref="upload"
  17. class="upload-demo"
  18. drag
  19. :action="url"
  20. :auto-upload="false"
  21. :limit="limit"
  22. :on-exceed="handleLimit"
  23. :http-request="uploadFile"
  24. multiple
  25. >
  26. <i class="el-icon-upload" />
  27. <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
  28. </el-upload>
  29. </el-tab-pane>
  30. <el-tab-pane label="Base64文件" name="2">
  31. <el-input
  32. v-model="form.base64"
  33. type="textarea"
  34. :autosize="{ minRows: 7, maxRows: 8 }"
  35. />
  36. </el-tab-pane>
  37. </el-tabs>
  38. <div class="dialog-footer">
  39. <el-button @click="cancel">关 闭</el-button>
  40. <el-button type="primary" @click="confirm">提 交</el-button>
  41. </div>
  42. </div>
  43. </template>
  44. <script>
  45. import request from '@/utils/request'
  46. export default {
  47. name: 'UploadForm',
  48. data() {
  49. return {
  50. url: process.env.VUE_APP_BASE_API + '/api/v1/public/uploadFile',
  51. activeTab: '1',
  52. form: {
  53. dataSource: '1',
  54. base64: ''
  55. },
  56. formData: '',
  57. limit: 10
  58. }
  59. },
  60. mounted() {},
  61. methods: {
  62. handleLimit(e) {
  63. if (e.length > this.limit) {
  64. this.$message({
  65. message: `最大单次只可上传${this.limit}条`,
  66. type: 'warning'
  67. })
  68. }
  69. },
  70. uploadFile(file) {
  71. this.formData.append('file', file.file)
  72. },
  73. confirm() {
  74. if (this.activeTab === '2') {
  75. this.formData = new FormData()
  76. this.formData.append('file', this.form.base64)
  77. this.formData.append('type', '3')
  78. } else {
  79. this.formData = new FormData()
  80. this.$refs.upload.submit()
  81. this.formData.append('type', '2')
  82. }
  83. request.post(this.url, this.formData, {
  84. 'Content-Type': 'multipart/form-data'
  85. }).then(ret => {
  86. if (ret.code === 200) {
  87. this.form.base64 = ''
  88. this.$refs.upload.clearFiles()
  89. this.$emit('confirm', Array.isArray(ret.data) ? ret.data : [ret.data])
  90. }
  91. })
  92. },
  93. cancel() {
  94. this.$emit('cancel')
  95. }
  96. }
  97. }
  98. </script>
  99. <style lang="scss" scoped>
  100. .form /deep/ {
  101. .el-upload {
  102. width: 100%;
  103. }
  104. .el-upload-dragger {
  105. width: 100%;
  106. }
  107. }
  108. .dialog-footer {
  109. padding: 30px 0;
  110. display: flex;
  111. justify-content: flex-end;
  112. align-items: center;
  113. }
  114. </style>