首页 > web前端 > js教程 > 如何修改 FormData 对象中的文件对象和 FileList 长度?

如何修改 FormData 对象中的文件对象和 FileList 长度?

DDD
发布: 2024-12-01 01:50:09
原创
280 人浏览过

How Can I Modify File Objects and FileList Length within a FormData Object?

修改 FormData 对象中的 File 对象和 FileList 长度

问题:

我们如何修改 FormData 对象中的 File 对象FileList 并设置其长度,确保文件反映在 FormData 中对象?

答案:

使用 DataTransfer

正如原始发布者 (OP) 所发现的,DataTransfer API 提供一种完成此任务的方法,尽管其当前存在局限性(仅由 Blink 支持,FF >= 62)。通过 DataTransferItemList 创建可变 FileList,我们可以在 HTML 文件输入元素的 FileList 上设置任意文件。


// 创建一个新的 DataTransfer 对象
const dT = new DataTransfer();

//将 File 对象添加到 DataTransferItemList
dT.items.add(new File(['foo'], 'programmatically_created.txt'));

// 将输入元素的 files 属性设置为DataTransfer 对象的文件
inp.files = dT.files;

<input type="file">

这种方法有效地修改了文件输入元素内的FileList,并且更新的文件将反映在FormData中

限制:

需要注意的是,该技术目前的浏览器支持有限。此外,不支持 DataTransfer 构造函数的浏览器可能需要一些后备行为。

以上是如何修改 FormData 对象中的文件对象和 FileList 长度?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
上一篇:如何成功链接并执行 GitHub 上托管的外部 JavaScript 文件? 下一篇:folderxt - LLM 的代码上下文
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
相关专题
更多>
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板