FormData对象能让你生成一系列用于XMLHttpRequest发送的键值对。它主要的目的在于发送表单数据,但也能独立用于传输有键形式的数据。其传输的数据格式和表单使用submit()方法、且编码类型为multipart/form-data
所发送的数据格式相同。
你可以自己建立一个FormData对象,首先进行实例化、再通过apppend()方法来添加字段,如下所示:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| var formData = new FormData(); formData.append("username", "Groucho"); formData.append("accountnum", 123456); formData.append("userfile", fileInputElement.files[0]); var content = '<a id="a"><b id="b">hey!</b></a>'; var blob = new Blob([content], { type: "text/xml"}); formData.append("webmasterfile", blob); var request = new XMLHttpRequest(); request.open("POST", "http://foo.com/submitform.php"); request.send(formData);
|
注意:“userfile”字段和“webmasterfile”字段都包含了文件。“accountnum”字段中的数字会自动被FormData.append()方法自动转为字符串。(字段值可以是一个Blob、File或字符串,若值不是Blob、File之一,就会被转为字符串)
上面的例子建立了一个包含名为“username”、“accountnum”、“userfile”和“webmasterfile”字段的FormData对象。然后使用了XMLHttpRequest的send()方法来发送表单数据。“webmasterfile”字段是个Blob对象,该对象代表了一个由不可变的、原始数据组成的类文件对象,里面的的数据不必使用JavaScript的原生数据类型。File对象也是基于Blob对象的,它继承了Blob的基本功能并做了拓展以支持用户操作系统上的文件。要建立一个Blob对象,你可以使用Blob构造函数。
要用现有的<form>
元素建立一个FormData对象,可以在建立FormData对象时传入指定的<form>
元素。
1
| var formData = new FormData(someFormElement);
|
举个例子:
1 2 3 4
| var formElement = document.querySelector("form"); var request = new XMLHttpRequest(); request.open("POST", "submitform.php"); request.send(new FormData(formElement));
|
在用<form>
元素建立FromData对象之后、发送它之前,也可以给它添加额外的数据,如下:
1 2 3 4 5 6
| var formElement = document.querySelector("form"); var formData = new FormData(formElement); var request = new XMLHttpRequest(); request.open("POST", "submitform.php"); formData.append("serialnumber", serialNumber++); request.send(formData);
|
这样一来我们就能在发送表单数据前进行配置,以添加一些不需用户编辑的信息。
你也可以用FormData对象发送文件,只需在你的<form>
标签间包含一个file
类型的<input>
元素:
1 2 3 4 5 6 7 8 9 10
| <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 /> <input type="submit" value="Stash the file!" /> </form> <div></div>
|
然后你就能用如下代码发送文件了:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| var form = document.forms.namedItem("fileinfo"); form.addEventListener('submit', function(ev) { var oOutput = document.querySelector("div"), oData = new FormData(form); 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 when trying to upload your file.<br \/>"; } }; oReq.send(oData); ev.preventDefault(); }, false);
|
注意:若你传入了一个表单的引用,那么表单指定的方法(译注:应指Post、Get)会覆盖open()方法调用时指定的。
你也可以直接添加File或Blob到FormData对象,如下:
1
| data.append("myfile", myBlob, "filename.txt");
|
使用append()方法时,使用第三个可选的参数会指定一个文件名,用于请求头的Content-Disposition
字段。若没有指定文件名(或者该参数不被支持),那就默认使用“blob”这个名字。
若你想了解如何基于AJAX进行序列化和发送表单操作,而不使用FormData对象,可阅读此文。
参见
Using XMLHttpRequest
HTMLFormElement
Blob
Typed Arrays