Home >Web Front-end >JS Tutorial >Use of FormData in JavaScript objects

Use of FormData in JavaScript objects

一个新手
一个新手Original
2017-09-06 13:20:191991browse

Usage of FormData object

In this article

  1. How to create a FormData object

  2. Created through HTML form FormData object

  3. Use the FormData object to upload files

  4. You can submit forms and upload files through AJAX without using the FormData object

  5. Related links


The FormData object can be used to assemble a set of key/value pairs for sending requests using XMLHttpRequest . It makes sending form data more flexible and convenient because it can be used independently of the form. If you set the encoding type of the form to multipart/form-data, the data format transmitted through FormData is the same as the data format transmitted by the form through the submit() method

How Create a FormData objectEdit

You can create a FormData object yourself and then add fields by calling its append() method, like this:


var formData = new FormData();

formData.append("username", "Groucho");
formData.append("accountnum", 123456); // 数字 123456 会被立即转换成字符串 "123456"// HTML 文件类型input,由用户选择formData.append("userfile", fileInputElement.files[0]);// JavaScript file-like 对象var content = '975f881abd041d8a9a52113a3d7608728ad3eee38b36f0786840bfc85b25539ahey!0d36329ec37a2cc24d42c7229b69747a5db79b134e9f6b82c0b36e0489ee08ed'; // 新文件的正文...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);

Note: Fields "userfile" and "webmasterfile" both contain a file. Field "accountnum" is of numeric type and will be FormData.append() method is converted to a string type (FormData The field type of the object can be Blob, File, or string: If its field type is neither Blob nor File, it will be converted to a string type.

The above example creates a FormData instance, containing "username", "accountnum", "userfile" and "webmasterfile" four fields, and then use the send() method of XMLHttpRequest to send the form data. The field "webmasterfile" is Blob##. #Type. A Blob object represents an immutable, raw data-like file object. The data represented by Blob is not necessarily a JavaScript native format. The File interface is based on Blob and inherits from blob. functionality and extends it to support files on the user's system. You can create a Blob object through the Blob() constructor

Create a FormData object from an HTML form Edit

If you want to construct a FormData object containing Form data, you need to specify the elements of the form when creating the FormData object


var formData = new FormData(someFormElement);
示例:var formElement = document.querySelector("form");var request = new XMLHttpRequest();
request.open("POST", "submitform.php");
request.send(new FormData(formElement));
#. ##You can also append additional data to the FormData object after creating a FormData object containing the Form form data and before sending the request, like this:

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);

You are free to append fields that are not necessarily user-editable to the form data before sending the request

Use the FormData object to upload files

EditYou can also use FormData to upload files. When using it, you need to add a file type input to the form:

ff146639ecf87721cba4be18b8688d52
  2e1cf0710519d5598b1f0f14c36ba674Your email address:8c1ecd4bb896b2264e0711597d40766c
  fdd4de8b295fab4aa0708ba29a56a4f8ff9d32c555bb1d9133a29eb4371c1213
  2e1cf0710519d5598b1f0f14c36ba674Custom file label:8c1ecd4bb896b2264e0711597d40766c
  3c2750d34148cf8c03cc62edc6c563efff9d32c555bb1d9133a29eb4371c1213
  2e1cf0710519d5598b1f0f14c36ba674File to stash:8c1ecd4bb896b2264e0711597d40766c
  965e00529aa4b86d8dd68bfcdaa48288
  5fa1d26c6939704a2c990d4281d4b44df5a47148e367a6035fd7a2faa965022ee388a4556c0f65e1904146cc1a846bee94b3e26ee717c64999d7867364b1b4a3

and then use the following code to send the request:

var form = document.forms.namedItem("fileinfo");
form.addEventListener('submit', function(ev) {  var oOutput = document.querySelector("p"),
      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.666a5bd9fab33f2f6688eb1baf827b5d";
    }
  };

  oReq.send(oData);
  ev.preventDefault();
}, false);


Note:

If the FormData object is created through a form, the request method specified in the form will be applied to the method open(). You can also directly attach File or Blob type files to the FormData object, as shown below:

data.append("myfile", myBlob, "filename.txt");

When using the appned() method, you can send a request through the third optional parameter setting The header

Content-Disposition

specifies the file name. If no filename is specified (or if this parameter is not supported), the name "blob" will be used. If you set the correct configuration items, you can also use the FormData object through jQuery:

var fd = new FormData(document.querySelector("form"));
fd.append("CustomField", "This is some extra data");
$.ajax({
  url: "stash.php",
  type: "POST",
  data: fd,
  processData: false,  // 不处理数据
  contentType: false   // 不设置内容类型});

The above is the detailed content of Use of FormData in JavaScript objects. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn