赞
踩
FormData 是一个用于在客户端创建表单数据的接口。它可以通过 JavaScript 中的 new FormData()
构造函数创建。FormData 可以将表单字段的键值对以键值对的方式添加,同时也支持添加文件。
在文件上传的场景中,我们可以使用 FormData 对象来收集表单数据,包括文件和其他文本字段,然后将其发送到后端服务器。
FormData 对象用于将数据编译成键值对,以便将其提交到服务器,它主要用于通过 XHR 传输文件。
使用 FormData 的主要优点:
Axios 可以通过 FormData 对象上传文件,主要有两种方法:
直接将文件对象作为 value,追加到 FormData 中,axios 会自动对文件进行编码。
- const formData = new FormData();
-
- formData.append('file', fileInput.files[0]); // fileInput 为 <input type="file" />
-
- axios.post('/upload', formData)
Axios 默认发送 JSON 数据,设置 headers 将 Content-Type 设置为 multipart/form-data 后,就会处理为 FormData 对象提交。
- const formData = new FormData();
-
- formData.append('file', fileInput.files[0]);
-
- axios.post('/upload', formData, {
- headers: {
- 'Content-Type': 'multipart/form-data'
- }
- })
为演示文件上传过程,本文将使用 Node.js 构建后端服务器。后端会提供 /upload
接口来处理文件上传请求。
1.首先,创建前端 HTML 页面,本文以 index.html
为例:
- <!DOCTYPE html>
- <html>
- <head>
- <title>文件上传示例</title>
- </head>
- <body>
- <input type="file" id="fileInput">
- <button onclick="uploadFile()">上传文件</button>
-
- <script src="axios.min.js"></script>
- <script src="main.js"></script>
- </body>
- </html>
2.然后,创建前端 JavaScript 文件 main.js
,用于实现文件上传的交互逻辑:
- function uploadFile() {
- const fileInput = document.querySelector('#fileInput');
- const file = fileInput.files[0];
-
- // 使用FormData对象上传文件
- const formData = new FormData();
- formData.append('file', file);
-
- axios.post('http://localhost:5500/upload', formData, {
- headers: {
- 'Content-Type': 'multipart/form-data'
- }
- }).then(response => {
- console.log('上传成功', response.data);
- }).catch(error => {
- console.error('上传失败', error);
- });
- }
3.最后,创建 Node.js 后端服务器脚本(可命名为 server.js
,用于接收并处理文件上传请求:
- const express = require("express");
- const multer = require("multer");
- const cors = require("cors"); // 引入cors中间件
- const app = express();
- const upload = multer({ dest: "uploads/" });
-
- // 使用cors中间件来设置CORS
- app.use(cors());
-
- app.post("/upload", upload.single("file"), (req, res) => {
- const file = req.file;
- console.log("已接收到文件", file);
- // 在此处进行文件保存或其他处理
- res.send({
- code: 200,
- data: "文件上传成功",
- });
- });
-
- app.listen(5500, () => {
- console.log("服务器已启动,监听端口 5500");
- });
当然,为使后端服务器正常运行,还需要安装以下 Node.js 扩展模块:
- npm install express
-
- npm install multer
-
- npm install cors
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。