使用FormData对象

使用FormData对象


  • TAGS 
  • 文件

利用FormData对象,你可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单".

创建一个FormData对象

你可以先创建一个空的FormData对象,然后使用append()方法向该对象里添加字段,如下:

var oMyForm = new FormData();

oMyForm.append("username", "Groucho");
oMyForm.append("accountnum", 123456); // 数字123456被立即转换成字符串"123456"

// fileInputElement中已经包含了用户所选择的文件
oMyForm.append("userfile", fileInputElement.files[0]);

var oFileBody = "<a id="a"><b id="b">hey!</b></a>"; // Blob对象包含的文件内容
var oBlob = new Blob([oFileBody], { type: "text/xml"});

oMyForm.append("webmasterfile", oBlob);

var oReq = new XMLHttpRequest();
oReq.open("POST", "http://foo.com/submitform.php");
oReq.send(oMyForm);
  
  
注: 字段"userfile"和"webmasterfile"的值都包含了一个文件.通过  FormData.append()方法赋给字段"accountnum"的数字被自动转换为字符(字段的值可以是一个 Blob对象,一个 File对象,或者一个字符串,剩下其他类型的值都会被自动转换成字符串).

在该例子中,我们创建了一个名为oMyForm的FormData对象,该对象中包含了名为"username", "accountnum", "userfile" 以及 "webmasterfile"的字段名,然后使用XMLHttpRequestsend()方法把这些数据发送了出去."webmasterfile"字段的值不是一个字符串,还是一个Blob对象.

使用HTML表单来初始化一个FormData对象

可以用一个已有的<form>元素来初始化FormData对象,只需要把这个form元素作为参数传入FormData构造函数即可:

var newFormData = new FormData(someFormElement);
  
  

例如:

var formElement = document.getElementById("myFormElement");
var oReq = new XMLHttpRequest();
oReq.open("POST", "submitform.php");
oReq.send(new FormData(formElement));
  
  

你还可以在已有表单数据的基础上,继续添加新的键值对,如下:

var formElement = document.getElementById("myFormElement");
formData = new FormData(formElement);
formData.append("serialnumber", serialNumber++);
oReq.send(formData);
  
  

你可以通过这种方式添加一些不想让用户编辑的固定字段,然后再发送.

使用FormData对象发送文件

你还可以使用FormData来发送二进制文件.首先在HTML中要有一个包含了文件输入框的form元素:

<form enctype="multipart/form-data" method="post" name="fileinfo">
  <label>Your email address:</label>
  <input type="email" autocomplete="on" autofocus name="userid" placeholder="email" required size="32" maxlength="64" /><br />
  <label>Custom file label:</label>
  <input type="text" name="filelabel" size="12" maxlength="32" /><br />
  <label>File to stash:</label>
  <input type="file" name="file" required />
</form>
<div id="output"></div>
<a href="javascript:sendForm()">Stash the file!</a>
   
   

然后你就可以使用下面的代码来异步的上传用户所选择的文件:

function sendForm() {
  var oOutput = document.getElementById("output");
  var oData = new FormData(document.forms.namedItem("fileinfo"));

  oData.append("CustomField", "This is some extra data");

  var oReq = new XMLHttpRequest();
  oReq.open("POST", "stash.php", true);
  oReq.onload = function(oEvent) {
    if (oReq.status == 200) {
      oOutput.innerHTML = "Uploaded!";
    } else {
      oOutput.innerHTML = "Error " + oReq.status + " occurred uploading your file.<br \/>";
    }
  };

  oReq.send(oData);
}
  
  

你还可以不借助HTML表单,直接向FormData对象中添加一个File对象或者一个Blob对象:

data.append("myfile", myBlob);
  
  

如果FormData对象中的某个字段值是一个Blob对象,则在发送http请求时,代表该Blob对象所包含文件的文件名的"Content-Disposition"请求头的值在不同的浏览器下有所不同,Firefox使用了固定的字符串"blob,"而Chrome使用了一个随机字符串.

你还可以使用jQuery来发送FormData,但必须要正确的设置相关选项:

var fd = new FormData(document.getElementById("fileinfo"));
fd.append("CustomField", "This is some extra data");
$.ajax({
  url: "stash.php",
  type: "POST",
  data: fd,
  processData: false,  // 告诉jQuery不要去处理发送的数据
  contentType: false   // 告诉jQuery不要去设置Content-Type请求头
});
<think>好的,我现在需要帮助用户了解如何使用axios和FormData在JavaScript中发送带有参数的POST请求。首先,我要回忆一下相关的知识点,确保自己理解正确。 首先,用户的问题是关于发送POST请求的,具体是使用axios库和FormData对象FormData通常用于上传文件或发送表单数据,尤其是multipart/form-data格式的数据。而axios是一个基于Promise的HTTP客户端,适用于浏览器和Node.js环境。 接下来,我需要整理步骤。首先,用户需要创建一个FormData对象,然后通过append方法添加参数。这可能包括文本字段和文件。然后,使用axios的post方法发送请求,设置正确的Content-Type头,通常是'multipart/form-data',不过axios可能会自动处理。 然后,我需要考虑可能的错误点,比如是否正确添加了所有参数,是否正确设置了请求头,以及如何处理服务器端的接收。例如,如果后端期望的是JSON格式,而发送的是FormData,可能会导致问题,所以需要确保前后端数据格式一致。 另外,可能需要提到如何查看请求是否成功,比如使用then和catch处理响应和错误。同时,用户可能需要处理跨域问题(CORS),但这可能超出了当前问题的范围,不过可以简要提及。 还要参考提供的引用内容。例如,引用[2]提到localStorage使用JSON.stringify,但这里可能不直接相关。引用[3]和[4]涉及使用函数获取数据和递归请求,可能与处理响应后的操作有关,比如在成功发送后更新前端状态或进行后续请求。 然后,生成相关问题时,需要考虑用户可能的后续疑问,比如如何处理文件上传、错误处理、调试技巧,以及替代方法如JSON格式发送数据等。 现在,需要确保回答结构清晰,分步骤说明,并提供代码示例。同时,检查是否满足系统级指令,比如行内数学公式是否正确使用,但在这个问题中可能不涉及数学公式,所以可能不需要。但如果有提到JSON或编码格式,可能需要用行内代码块而非数学公式。 最后,验证代码示例是否正确,比如创建FormData对象,添加参数,发送请求,处理响应。确保代码没有语法错误,并符合最佳实践,比如使用async/await或Promise链。</think>要使用axios通过FormData对象发送带参数的POST请求,可按以下步骤操作: ### 一、创建FormData对象 ```javascript const formData = new FormData(); formData.append('username', 'john_doe'); // 文本参数 formData.append('avatar', fileInput.files[0]); // 文件参数 ``` ### 二、发送POST请求 ```javascript axios.post('/upload', formData, { headers: { 'Content-Type': 'multipart/form-data' // axios会自动识别可不写[^2] } }) .then(response => { console.log('上传成功:', response.data); }) .catch(error => { console.error('上传失败:', error); }); ``` ### 三、服务端处理 以Node.js/Express为例: ```javascript app.post('/upload', uploadMiddleware, (req, res) => { console.log(req.body.username); // 获取文本参数 console.log(req.file); // 获取上传文件 res.send('文件已接收'); }); ``` ### 关键注意事项 1. **文件参数**必须通过`<input type="file">`获取文件对象 2. **混合参数**可同时添加文本和文件字段[^3] 3. **内容类型**不要手动设置,axios会自动识别[^2] 4. **调试技巧**可通过浏览器开发者工具的Network面板查看实际发送的请求格式
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值