MENU

「JavaScript」修改 input type="file" 元素的文件对象

2022 年 05 月 25 日 • 开发

参考信息

示例代码

let fileItem = new File([blob], "example.txt", {
  type: "txet/plain",
  lastModified: Date.now(),
});
let container = new DataTransfer();

container.items.add(fileItem);
fileInputElement.files = container.files;

应用场景

通过 form 提交自定义的文件:

let container = new DataTransfer();
let file = new File([blob], 'tp_tmp.zip');

let frame = document.createElement('iframe');
let form = document.createElement('form');
let input = document.createElement('input');

container.items.add(file);

frame.setAttribute('name', 'form-result');

form.setAttribute('action', `http://${localDeviceIP}:10808/ProcessServer/FileOperate/fileUpServlet`);
form.setAttribute('enctype', 'multipart/form-data');
form.setAttribute('method', 'post');
form.setAttribute('target', 'form-result');
form.appendChild(input);

input.setAttribute('name', 'file');
input.setAttribute('type', 'file');
input.files = container.files;

document.body.appendChild(frame);
document.body.appendChild(form);

form.submit();
最后编辑于: 2024 年 10 月 17 日