0

0

如何利用javascript实现文件上传功能_ajax和formdata怎么配合使用

夢幻星辰

夢幻星辰

发布时间:2026-01-09 19:13:02

|

214人浏览过

|

来源于php中文网

原创

FormData 是浏览器专为表单提交(尤其含文件)设计的二进制容器,能自动处理 boundary、编码和 multipart 格式;直接传 JS 对象会导致文件二进制数据丢失,必须用 FormData.append() 添加文件或字段,fetch 会自动设置正确 Content-Type。

如何利用javascript实现文件上传功能_ajax和formdata怎么配合使用

FormData 是什么,为什么不能直接传对象

浏览器原生 XMLHttpRequestfetch 无法直接把普通 JS 对象(比如 {file: fileInput.files[0], name: "test"})发给后端做文件上传。服务端收到的只是字符串化的键值对,文件二进制数据会丢失。必须用 FormData —— 它是浏览器专为表单提交(尤其是含文件)设计的二进制容器,能自动处理边界(boundary)、编码和 multipart 格式。

常见错误:手动把 File 对象 JSON.stringify 后塞进 body,结果后端收不到文件字段,只看到一串乱码或空值。

  • FormData 实例可直接作为 fetchbody,无需设 Content-Type 头(浏览器会自动设置并带上正确的 boundary
  • 不能用 JSON.stringify 包裹 FormData,否则它就变成字符串,失去二进制能力
  • 添加字段时,append() 第二个参数如果是 FileBlob,浏览器会自动提取文件名;如果只是字符串,就当普通文本字段

用 fetch + FormData 上传单个文件的最小可行代码

这是最常遇到的场景:用户选一个文件,点击上传按钮,前端把文件连同额外参数(如 id、type)一起发给接口。

const uploadFile = async (file, extraData = {}) => {
  const formData = new FormData();
  formData.append('file', file); // 必须是 File 对象,不是 fileInput.files[0].name
  Object.keys(extraData).forEach(key => {
    formData.append(key, extraData[key]);
  });

try { const res = await fetch('/api/upload', { method: 'POST', body: formData // 直接传,不要加 headers: {'Content-Type': 'multipart/form-data'} }); return await res.json(); } catch (err) { console.error('上传失败:', err); } };

// 调用示例 document.getElementById('fileInput').addEventListener('change', e => { if (e.target.files.length > 0) { uploadFile(e.target.files[0], { type: 'avatar', userId: '123' }); } });

注意:fetch 内部会自动设置 Content-Typemultipart/form-data; boundary=xxxx,手动覆盖会导致后端解析失败。

立即学习Java免费学习笔记(深入)”;

上传多个文件时 append 的写法差异

后端是否支持数组字段(如 files[])取决于框架。Node.jsmulter、PHP 的 $_FILES 默认把同名多文件当作数组,但需要前端统一字段名。

剪刀手
剪刀手

全自动AI剪辑神器:日剪千条AI原创视频,零非原创风险,批量高效制作引爆流量!免费体验,轻松上手!

下载
  • 如果后端接收字段叫 files,且期望是数组:所有文件都用 formData.append('files', file)(相同 key)
  • 如果后端按索引接收(如 files[0], files[1]):需手动拼 key,如 formData.append(`files[${i}]`, file)
  • 混合上传(多个文件 + 文本字段)完全没问题,FormData 支持任意顺序 append

错误做法:试图用 formData.append('files', [file1, file2]) —— 这只会把数组转成字符串 "[object File],[object File]",后端收不到真实文件。

监听上传进度时为什么 onprogress 只在 XMLHttpRequest 里有效

fetch 没有原生上传进度事件,只能靠 XMLHttpRequestupload.onprogress。如果你需要显示「上传中 65%」,就得切回 XMLHttpRequest

const xhrUpload = (file, extraData) => {
  const formData = new FormData();
  formData.append('file', file);
  Object.entries(extraData).forEach(([k, v]) => formData.append(k, v));

return new Promise((resolve, reject) => { const xhr = new XMLHttpRequest(); xhr.upload.onprogress = e => { if (e.lengthComputable) { const percent = (e.loaded / e.total) * 100; console.log(上传进度: ${percent.toFixed(1)}%); } }; xhr.onload = () => resolve(xhr.response); xhr.onerror = reject; xhr.open('POST', '/api/upload'); xhr.send(formData); }); };

关键点:xhr.upload 是上传专用事件对象,xhr.onprogress 是下载进度,别混淆。另外,XMLHttpRequest 不支持 async/await 直接等待,必须包装成 Promise。

真正容易被忽略的是:某些 CDN 或代理(如 Nginx)默认限制单次请求体大小,即使前端没报错,后端也可能收不到完整文件——这时要检查服务端配置(如 Nginx 的 client_max_body_size),而不是反复改前端代码。

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2308

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1523

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1414

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

951

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1413

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1233

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1445

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1304

2023.11.13

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号