el-upload 上传图片文件方法

文章讲述了如何覆盖HTTP请求的默认行为,特别是在上传文件时,设置Content-Type为multipart/form-data并使用FormData处理数据。它提到了使用axios库进行POST请求,并展示了一个使用el-upload组件的Vue.js示例,该组件允许自定义http-request方法来实现文件上传,并提供了校验和显示文件列表的功能。
摘要由CSDN通过智能技术生成

好文链接

覆盖action的默认请求行为是必要的 http-request,自定义上传方法

Content-Type 设置成 form-data

Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryBicOUjQSEgA1dSB1

以 formData 格式处理data

let files = new FormData()
files.append('file', xxxfile)
// 发起 post 请求
function uploadapi(data) {
  return axios.post('url', {headers:{'Content-Type':'multipart/form-data'}})
}

使用 el-upload 组件做上传交互

<el-upload
  action="#"
  ref="upload"
  accept=".xls,.xlsx" 
  :show-file-list="false"
  :http-request="upload"
>
  <el-button
    type="text"
    icon="el-icon-upload"
    style="float: right"
  >上传附件
  </el-button>
</el-upload>
upload(param) {
  const data = new FormData()
  data.append('file', param.file) // 'file'为name 需规定清楚
  uploadapi(data).then(res => {
    if (res.success) {
      this.$message.success(res.message)
      // 涉及到刷新
    }
  })
}

插槽

  • default 自定义默认内容
  • trigger 触发文件选择框的内容
  • tip 提示说明文字
  • file 缩略图模板的内容 { file: UploadFile }

格式需要在上传前进行校验 before-upload
accept 仅在文件选择时自动筛选,可被手动取消

显示文件列表 file-list
自动上传 auto-upload

默认方法是单个文件提交的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值