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]);
  });
<p>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);
}
};</p><p>// 调用示例
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免费学习笔记(深入)”;

What-the-Diff
What-the-Diff

检查请求差异,自动生成更改描述

下载

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

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

  • 如果后端接收字段叫 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));
<p>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(<code>上传进度: ${percent.toFixed(1)}%</code>);
}
};
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),而不是反复改前端代码。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

246

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

522

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

610

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

693

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3618

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

54

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

71

2026.01.13

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

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

共137课时 | 13.3万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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