Ant Design Pro图片上传

之前我写了一篇利用springboot将图片保存在本地的代码,现在前端使用Ant Design Pro与后台交互
新建表单的vue

<template>
  <a-modal
    title="配置项"
    :width="640"
    :visible="visible"
    :confirmLoading="confirmLoading"
    @ok="handleSubmit"
    @cancel="handleCancel"
  >
    <a-spin :spinning="confirmLoading">
      <a-form :form="form">
        <a-form-item
          label="上传文件"
          :labelCol="labelCol"
          :wrapperCol="wrapperCol">
          <a-upload
            :file-list="fileList"
            :remove="handleRemove"
            :before-upload="beforeUpload"
          >
            <a-button> <a-icon type="upload"/> 选择图片或视频 </a-button>
          </a-upload>
        </a-form-item>
        <a-form-item
          label="上传人"
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
        >
          <a-input v-decorator="['uploadUser', {rules: [{required: true}]}]"/>
        </a-form-item>
      </a-form>
    </a-spin>
  </a-modal>
</template>

<script>

  export default {
    data () {
      return {
        labelCol: {
          xs: { span: 24 },
          sm: { span: 7 }
        },
        wrapperCol: {
          xs: { span: 24 },
          sm: { span: 13 }
        },
        visible: false,
        confirmLoading: false,
        form: this.$form.createForm(this),
        fileList: []
      }
    },
    methods: {
      handleSubmit (file) {
        const { form: { validateFields } } = this
        const { fileList } = this
        const formData = new FormData()
        fileList.forEach(file => {
          formData.append('file', file)
        })
        validateFields((errors, values) => {
          formData.append('uploadUser', values.uploadUser)
          axios(
          {
            url: '*/upload',
            method: 'post',
            data: formData,
            timeout: 9000000, //这个就是重点 因为上传时间过长,http请求时间过长,来不及回复。
			headers: {
      			'Content-Type': 'multipart/form-data;boundary = ' + new Date().getTime()
   			 }
          }).then(res => {
            if (res.code === 200) {
            	this.$message.success('图片上传成功')
            } else {
                this.$message.error('图片上传失败')
            }
          }
        )
        })
      },
      handleCancel () {
        this.visible = false
      },
      handleRemove (file) {
        const index = this.fileList.indexOf(file)
        const newFileList = this.fileList.slice()
        newFileList.splice(index, 1)
        this.fileList = newFileList
      },
      beforeUpload (file) {
        this.fileList = [...this.fileList, file]
        return false
      }
    }
  }
</script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值