我还在试着接受这件事。

我可以让用户选择文件(甚至多个)与文件输入:

<form>
  <div>
    <label>Select file to upload</label>
    <input type="file">
  </div>
  <button type="submit">Convert</button>
</form>

我可以用<填充事件处理程序>来捕获提交事件。但是一旦我这样做了,我如何使用fetch发送文件?

fetch('/files', {
  method: 'post',
  // what goes here? What is the "body" for this? content-type header?
}).then(/* whatever */);

当前回答

对我来说,问题是我正在使用response.blob()填充表单数据。显然你不能这样做,至少用react native,所以我最终使用

data.append('fileData', {
  uri : pickerResponse.uri,
  type: pickerResponse.type,
  name: pickerResponse.fileName
 });

Fetch似乎可以识别该格式,并将文件发送到uri指向的位置。

其他回答

如何上传一个文件选择使用HTML5获取

<label role="button">
  Upload a picture
  <input accept="image/*" type="file" hidden />
</label>
const input = document.querySelector(`input[type="file"]`);

function upload() {
  fetch(uplaodURL, { method: "PUT", body: input.files[0] });
}

input.addEventListener("change", upload); 

如果你想要多个文件,你可以使用这个

var input = document.querySelector('input[type="file"]')

var data = new FormData()
for (const file of input.files) {
  data.append('files',file,file.name)
}

fetch('/avatars', {
  method: 'POST',
  body: data
})

使用Fetch API发送文件的一个重要注意事项

我们需要忽略Fetch请求的内容类型头。然后浏览器会自动添加内容类型头,包括表单边界,看起来像

Content-Type: multipart/form-data; boundary=—-WebKitFormBoundaryfgtsKTYLsT7PNUVD

表单边界是表单数据的分隔符

对我来说,问题是我正在使用response.blob()填充表单数据。显然你不能这样做,至少用react native,所以我最终使用

data.append('fileData', {
  uri : pickerResponse.uri,
  type: pickerResponse.type,
  name: pickerResponse.fileName
 });

Fetch似乎可以识别该格式,并将文件发送到uri指向的位置。

我是这样做的:

var input = document.querySelector('input[type="file"]')

var data = new FormData()
data.append('file', input.files[0])
data.append('user', 'hubot')

fetch('/avatars', {
  method: 'POST',
  body: data
})