Jquery 从 FormData 对象中删除值

Jquery delete value from FormData object

如何从具有相同名称的 FormData 对象中删除值? 我有包含两个输入文件的 HTML 表单。

<input id="human" type="file" name="file[]" class="docfiles" />
<input id="animal" type="file" name="file[]" class="docfiles" />

例如我想删除文件 1 - id "human"。知道怎么做吗?

这是我的演示 jsfiddle

如果您使用 jQuery,您可以使用

$("#human").remove();

如果您使用的是 vanilla JS,您可以执行以下操作

var human = document.getElementById('human');
human.parentNode.removeChild(human);

您可以通过将输入对象的值属性设置为空字符串来删除整个文件列表。

document.getElementById('human').value = "";

如果你使用的是FormData,你还可以

ForEach(var key in formData.keys()){
  formData.delete(key);
}

这将遍历 formData 中的所有键并删除所有键值对。

处理文件数组和re-add元素减去需要删除的元素。

var files = formData.getAll("file[]");
files.splice($("[type='file']").index($("#animal")), 1);
formData.delete("file[]");
$.each(files, function(i, v) {
    formData.append("file[]", v);
});

演示 https://jsfiddle.net/nnte528L/