This is a work in progress! For the latest updates from the HTML WG, possibly including important bug fixes, please look at the editor's draft instead.
A form-associated element can have a relationship
  with a form element, which is called the element's
  form owner. If a form-associated element is
  not associated with a form element, its form
  owner is said to be null.
A form-associated element is, by default, associated
  with its nearest ancestor
  form element (as described
  below), but may have a form attribute specified to
  override this.
This feature allows authors to work around the lack
  of support for nested form elements.
If a form-associated element has a form attribute specified, then that
  attribute's value must be the ID of a form element in
  the element's owner Document.
The rules in this section are complicated by the
  fact that although conforming documents will never contain nested
  form elements, it is quite possible (e.g. using a
  script that performs DOM manipulation) to generate documents that
  have such nested elements. They are also complicated by rules in the
  HTML parser that, for historical reasons, can result in a
  form-associated element being associated with a
  form element that is not its ancestor.
When a form-associated element is created, its form owner must be initialized to null (no owner).
When a form-associated element is to be associated with a form, its form owner must be set to that form.
When a form-associated element's ancestor chain
  changes, e.g. because it or one of its ancestors was inserted or removed from a
  Document, then the user agent must reset the form
  owner of that element. The HTML
  parser overrides this requirement when inserting form
  controls.
When a form-associated element's form attribute is added, removed, or
  has its value changed, then the user agent must reset the form
  owner of that element.
When a form-associated element has a form attribute and the ID of any of the
  elements in the Document changes, then the user agent
  must reset the form owner of that form-associated
  element.
When a form-associated element has a form attribute and an element with an
  ID is inserted
  into or removed from the Document, then the
  user agent must reset the form owner of that
  form-associated element.
When the user agent is to reset the form owner of a form-associated element, it must run the following steps:
If the element's form owner is not null, and
   the element's form content
   attribute is not present, and the element's form owner
   is its nearest form element ancestor after the change
   to the ancestor chain, then do nothing, and abort these
   steps.
Let the element's form owner be null.
If the element has a form
    content attribute, then run these substeps:
If the first element in the
     Document to have an ID that is case-sensitively equal to the
     element's form content
     attribute's value is a form element, then associate the
     form-associated element with that form
     element.
Abort the "reset the form owner" steps.
Otherwise, if the form-associated element in
   question has an ancestor form element, then associate the
   form-associated element with the nearest such ancestor
   form element.
Otherwise, the element is left unassociated.
In the following non-conforming snippet:
...
 <form id="a">
  <div id="b"></div>
 </form>
 <script>
  document.getElementById('b').innerHTML =
     '<table><tr><td><form id="c"><input id="d"></table>' +
     '<input id="e">';
 </script>
...
   The form owner of "d" would be the inner nested form "c", while the form owner of "e" would be the outer form "a".
This happens as follows: First, the "e" node gets associated
   with "c" in the HTML parser. Then, the innerHTML algorithm moves the nodes
   from the temporary document to the "b" element. At this point, the
   nodes see their ancestor chain change, and thus all the "magic"
   associations done by the parser are reset to normal ancestor
   associations.
This example is a non-conforming document, though, as it is a
   violation of the content models to nest form
   elements.
formReturns the element's form owner.
Returns null if there isn't one.
Form-associated
  elements have a form IDL attribute, which,
  on getting, must return the element's form owner, or
  null if there isn't one.
The name content
  attribute gives the name of the form control, as used in form
  submission and in the form element's elements object. If the attribute
  is specified, its value must not be the empty string.
Any non-empty value for name
  is allowed, but the names "_charset_" and "isindex" are special:
isindexThis value, if used as the name of a Text control that is the only
    control in a form that is submitted using the application/x-www-form-urlencoded
    mechanism, causes the submission to only include the value of this
    control, with no name.
_charset_This value, if used as the name of a Hidden control with no value attribute, is automatically
    given a value during submission consisting of the submission
    character encoding.
The disabled
  content attribute is a boolean attribute.
A form control is disabled
  if its disabled attribute is
  set, or if it is a descendant of a fieldset element
  whose disabled attribute
  is set and is not a descendant of that
  fieldset element's first legend element
  child, if any.
A form control that is disabled must prevent any click events that are queued on the user interaction task
  source from being dispatched on the element.
Constraint validation: If an element is disabled, it is barred from constraint validation.
The disabled IDL
  attribute must reflect the disabled content attribute.
Form controls have a value
  and a checkedness. (The latter
  is only used by input elements.) These are used to
  describe how the user interacts with the control.
To define the behaviour of constraint validation in the face of
  the input element's multiple attribute,
  input elements can also have separately defined values.
The autofocus
  content attribute allows the author to indicate that a control is to
  be focused as soon as the page is loaded, allowing the user to just
  start typing without having to manually focus the main control.
The autofocus attribute is
  a boolean attribute.
There must not be more than one element in the document with the
  autofocus attribute
  specified.
When an element with the autofocus attribute specified is
  inserted into a
  document, user agents should run the following steps:
Let target be the element's
   Document.
If target has no browsing context, abort these steps.
If target's browsing context has no top-level browsing context (e.g. it is a nested browsing context with no parent browsing context), abort these steps.
If target's browsing context had the sandboxed automatic features browsing context flag set when target was created, abort these steps.
If target's origin is not
   the same as the
   origin of the Document of the currently
   focused element in target's top-level
   browsing context, abort these steps.
If target's origin is not the same as the origin of the active document of target's top-level browsing context, abort these steps.
If the user agent has already reached the last step of this
   list of steps in response to an element being inserted into a
   Document whose top-level browsing
   context's active document is the same as target's top-level browsing context's
   active document, abort these steps.
If the user has indicated (for example, by starting to type in a form control) that he does not wish focus to be changed, then optionally abort these steps.
Queue a task that checks to see if the element is focusable, and if so, runs the focusing steps for that element. User agents may also change the scrolling position of the document, or perform some other action that brings the element to the user's attention. The task source for this task is the DOM manipulation task source.
Focusing the control does not imply that the user agent must focus the browser window if it has lost focus.
The autofocus
  IDL attribute must reflect the content attribute of the
  same name.
In the following snippet, the text control would be focused when the document was loaded.
<input maxlength="256" name="q" value="" autofocus> <input type="submit" value="Search">
A form control maxlength attribute, controlled by a dirty value flag declares a limit on the number of
  characters a user can input.
If an element has its form
  control maxlength attribute specified,
  the attribute's value must be a valid non-negative
  integer. If the attribute is specified and applying the
  rules for parsing non-negative integers to its value
  results in a number, then that number is the element's maximum
  allowed value length. If the attribute is omitted or parsing
  its value results in an error, then there is no maximum
  allowed value length.
Constraint validation: If an element has a maximum allowed value length, and its dirty value flag is true, and the code-point length of the element's value is greater than the element's maximum allowed value length, then the element is suffering from being too long.
User agents may prevent the user from causing the element's value to be set to a value whose code-point length is greater than the element's maximum allowed value length.
Attributes for form submission can be specified both
  on form elements and on submit buttons (elements that
  represent buttons that submit forms, e.g. an input
  element whose type attribute is
  in the Submit Button
  state).
  
The attributes for form submission that may be
  specified on form elements are action, enctype, method, novalidate, and target.
The corresponding attributes for form submission
  that may be specified on submit
  buttons are formaction, formenctype, formmethod, formnovalidate, and formtarget. When omitted, they
  default to the values given on the corresponding attributes on the
  form element.
The action and
  formaction
  content attributes, if specified, must have a value that is a
  valid URL potentially surrounded by spaces.
The action of an element is
  the value of the element's formaction attribute, if the
  element is a submit
  button and has such an attribute, or the value of its
  form owner's action
  attribute, if it has one, or else the empty string.
The method and
  formmethod
  content attributes are enumerated
  attributes with the following keywords and states:
get, mapping
   to the state GET, indicating
   the HTTP GET method.post, mapping
   to the state POST, indicating
   the HTTP POST method.The missing value default for these attributes is the GET state.
The method of an element is
  one of those states. If the element is a submit button and has a formmethod attribute, then the
  element's method is that
  attribute's state; otherwise, it is the form owner's
  method attribute's state.
The enctype and
  formenctype
  content attributes are enumerated
  attributes with the following keywords and states:
application/x-www-form-urlencoded" keyword and corresponding state.multipart/form-data" keyword and corresponding state.text/plain" keyword and corresponding state.The missing value default for these attributes is the
  application/x-www-form-urlencoded
  state.
The enctype of an element
  is one of those three states. If the element is a submit button and has a formenctype attribute, then the
  element's enctype is that
  attribute's state; otherwise, it is the form owner's
  enctype attribute's state.
The target and
  formtarget
  content attributes, if specified, must have values that are valid browsing
  context names or keywords.
The target of an element is
  the value of the element's formtarget attribute, if the
  element is a submit
  button and has such an attribute; or the value of its
  form owner's target
  attribute, if it has such an attribute; or, if the
  Document contains a base element with a
  target attribute, then the
  value of the target attribute
  of the first such base element; or, if there is no such
  element, the empty string.
The novalidate
  and formnovalidate
  content attributes are boolean
  attributes. If present, they indicate that the form is not to
  be validated during submission.
The no-validate state of
  an element is true if the element is a submit button and the element's
  formnovalidate attribute
  is present, or if the element's form owner's novalidate attribute is present,
  and false otherwise.
This attribute is useful to include "save" buttons on forms that have validation constraints, to allow users to save their progress even though they haven't fully entered the data in the form. The following example shows a simple form that has two required fields. There are three buttons: one to submit the form, which requires both fields to be filled in; one to save the form so that the user can come back and fill it in later; and one to cancel the form altogether.
<form action="editor.cgi" method="post"> <p><label>Name: <input required name=fn></label></p> <p><label>Essay: <textarea required name=essay></textarea></label></p> <p><input type=submit name=submit value="Submit essay"></p> <p><input type=submit formnovalidate name=save value="Save essay"></p> <p><input type=submit formnovalidate name=cancel value="Cancel"></p> </form>
The action and target IDL attributes must
  reflect the respective content attributes of the same
  name. The method and
  enctype IDL
  attributes must reflect the respective content
  attributes of the same name, limited to only known
  values. The encoding IDL attribute
  must reflect the enctype content attribute,
  limited to only known values. The noValidate IDL
  attribute must reflect the novalidate content attribute. The
  formAction IDL
  attribute must reflect the formaction content attribute. The
  formEnctype IDL
  attribute must reflect the formenctype content attribute,
  limited to only known values. The formMethod IDL
  attribute must reflect the formmethod content attribute,
  limited to only known values. The formNoValidate IDL
  attribute must reflect the formnovalidate content
  attribute. The formTarget IDL
  attribute must reflect the formtarget content attribute.
  
A form control dirname attribute
  on a form control element enables the submission of the
  directionality of the element, and gives the name of the
  field that contains this value during form submission.
  If such an attribute is specified, its value must not be the empty
  string.
The input and textarea elements define
  the following members in their DOM interfaces for handling their
  selection:
  void select();
           attribute unsigned long selectionStart;
           attribute unsigned long selectionEnd;
  void setSelectionRange(in unsigned long start, in unsigned long end);These methods and attributes expose and control the selection of
  input and textarea text fields.
select()Selects everything in the text field.
selectionStart [ = value ]Returns the offset to the start of the selection.
Can be set, to change the start of the selection.
selectionEnd [ = value ]Returns the offset to the end of the selection.
Can be set, to change the end of the selection.
setSelectionRange(start, end)Changes the selection to cover the given substring.
When these methods and attributes are used with
  input elements while they don't apply, they must raise
  an INVALID_STATE_ERR exception. Otherwise, they must
  act as described below.
For input elements, these methods and attributes
  must operate on the element's value. For textarea
  elements, these methods and attributes must operate on the element's
  raw value.
The select() method
  must cause the contents of the text field to be fully selected.
The selectionStart
  attribute must, on getting, return the offset (in logical order) to
  the character that immediately follows the start of the
  selection. If there is no selection, then it must return the offset
  (in logical order) to the character that immediately follows the
  text entry cursor.
On setting, it must act as if the setSelectionRange()
  method had been called, with the new value as the first argument,
  and the current value of the selectionEnd
  attribute as the second argument, unless the current value of the
  selectionEnd is
  less than the new value, in which case the second argument must also
  be the new value.
The selectionEnd
  attribute must, on getting, return the offset (in logical order) to
  the character that immediately follows the end of the selection. If
  there is no selection, then it must return the offset (in logical
  order) to the character that immediately follows the text entry
  cursor.
On setting, it must act as if the setSelectionRange()
  method had been called, with the current value of the selectionStart
  attribute as the first argument, and new value as the second
  argument.
The setSelectionRange(start, end) method
  must set the selection of the text field to the sequence of
  characters starting with the character at the startth position (in logical order) and ending with
  the character at the (end-1)th position. Arguments greater than the
  length of the value in the text field must be treated as pointing at
  the end of the text field. If end is less than
  or equal to start then the start of the
  selection and the end of the selection must both be placed
  immediately before the character with offset end. In UAs where there is no concept of an empty
  selection, this must set the cursor to be just before the character
  with offset end.
To obtain the currently selected text, the following JavaScript suffices:
var selectionText = control.value.substring(control.selectionStart, control.selectionEnd);
Characters with no visible rendering, such as U+200D ZERO WIDTH JOINER, still count as characters. Thus, for instance, the selection can include just an invisible character, and the text insertion cursor can be placed to one side or another of such a character.
A listed form-associated
  element is a candidate for constraint validation
  except when a condition has barred the element from constraint
  validation. (For example, an element is barred from
  constraint validation if it is an output or
  fieldset element.)
An element can have a custom validity error message
  defined. Initially, an element must have its custom validity
  error message set to the empty string. When its value is not
  the empty string, the element is suffering from a custom
  error. It can be set using the setCustomValidity()
  method. The user agent should use the custom validity error
  message when alerting the user to the problem with the
  control.
An element can be constrained in various ways. The following is the list of validity states that a form control can be in, making the control invalid for the purposes of constraint validation. (The definitions below are non-normative; other parts of this specification define more precisely when each state applies or does not.)
When a control has no value but has a required attribute (input required, select
   required,
   textarea required). 
When a control that allows arbitrary user input has a value that is not in the correct syntax (E-mail, URL).
When a control has a value that doesn't satisfy the
   pattern attribute.
When a control has a value that is too long for the
   form control maxlength attribute (input
   maxlength,
   textarea maxlength). 
When a control has a value that is too low for the min attribute.
When a control has a value that is too high for the
   max attribute.
When a control has a value that doesn't fit the rules
   given by the step
   attribute.
When a control's custom validity error
   message (as set by the element's setCustomValidity()
   method) is not the empty string.
An element can still suffer from these states even when the element is disabled; thus these states can be represented in the DOM even if validating the form during submission wouldn't indicate a problem to the user.
An element satisfies its constraints if it is not suffering from any of the above validity states.
When the user agent is required to statically validate the
  constraints of form element form, it must run the following steps, which return
  either a positive result (all the controls in the form are
  valid) or a negative result (there are invalid controls)
  along with a (possibly empty) list of elements that are invalid and
  for which no script has claimed responsibility:
Let controls be a list of all the submittable elements whose form owner is form, in tree order.
Let invalid controls be an initially empty list of elements.
For each element field in controls, in tree order, run the following substeps:
If field is not a candidate for constraint validation, then move on to the next element.
Otherwise, if field satisfies its constraints, then move on to the next element.
Otherwise, add field to invalid controls.
If invalid controls is empty, then return a positive result and abort these steps.
Let unhandled invalid controls be an initially empty list of elements.
For each element field in invalid controls, if any, in tree order, run the following substeps:
Fire a simple event named invalid that is cancelable at field.
If the event was not canceled, then add field to unhandled invalid controls.
Return a negative result with the list of elements in the unhandled invalid controls list.
If a user agent is to interactively validate the
  constraints of form element form, then the user agent must run the following
  steps:
Statically validate the constraints of form, and let unhandled invalid controls be the list of elements returned if the result was negative.
If the result was positive, then return that result and abort these steps.
Report the problems with the constraints of at least one of
   the elements given in unhandled invalid
   controls to the user. User agents may focus one of those
   elements in the process, by running the focusing steps
   for that element, and may change the scrolling position of the
   document, or perform some other action that brings the element to
   the user's attention. User agents may report more than one
   constraint violation. User agents may coalesce related constraint
   violation reports if appropriate (e.g. if multiple radio buttons in
   a group are marked as
   required, only one error need be reported). If one of the controls
   is not being rendered (e.g. it has the hidden attribute set) then user agents
   may report a script error.
Return a negative result.
willValidateReturns true if the element will be validated when the form is submitted; false otherwise.
setCustomValidity(message)Sets a custom error, so that the element would fail to validate. The given message is the message to be shown to the user when reporting the problem to the user.
If the argument is the empty string, clears the custom error.
validity . valueMissingReturns true if the element has no value but is a required field; false otherwise.
validity . typeMismatchReturns true if the element's value is not in the correct syntax; false otherwise.
validity . patternMismatchReturns true if the element's value doesn't match the provided pattern; false otherwise.
validity . tooLongReturns true if the element's value is longer than the provided maximum length; false otherwise.
validity . rangeUnderflowReturns true if the element's value is lower than the provided minimum; false otherwise.
validity . rangeOverflowReturns true if the element's value is higher than the provided maximum; false otherwise.
validity . stepMismatchReturns true if the element's value doesn't fit the rules given by the step attribute; false otherwise.
validity . customErrorReturns true if the element has a custom error; false otherwise.
validity . validReturns true if the element's value has no validity problems; false otherwise.
checkValidity()Returns true if the element's value has no validity problems;
    false otherwise. Fires an invalid event at the element in the
    latter case.
validationMessageReturns the error message that would be shown to the user if the element was to be checked for validity.
The willValidate
  attribute must return true if an element is a candidate for
  constraint validation, and false otherwise (i.e. false if any
  conditions are barring it from constraint validation).
The setCustomValidity(message), when invoked, must set the
  custom validity error message to the value of the given
  message argument.
In the following example, a script checks the value of a form
   control each time it is edited, and whenever it is not a valid
   value, uses the setCustomValidity() method
   to set an appropriate message.
<label>Feeling: <input name=f type="text" oninput="check(this)"></label>
<script>
 function check(input) {
   if (input.value == "good" ||
       input.value == "fine" ||
       input.value == "tired") {
     input.setCustomValidity('"' + input.value + '" is not a feeling.');
   } else {
     // input is fine -- reset the error message
     input.setCustomValidity('');
   }
 }
</script>
  The validity
  attribute must return a ValidityState object that
  represents the validity states of the element. This
  object is live, and the same object must be returned
  each time the element's validity attribute is retrieved.
interface ValidityState {
  readonly attribute boolean valueMissing;
  readonly attribute boolean typeMismatch;
  readonly attribute boolean patternMismatch;
  readonly attribute boolean tooLong;
  readonly attribute boolean rangeUnderflow;
  readonly attribute boolean rangeOverflow;
  readonly attribute boolean stepMismatch;
  readonly attribute boolean customError;
  readonly attribute boolean valid;
};
  A ValidityState object has the following
  attributes. On getting, they must return true if the corresponding
  condition given in the following list is true, and false
  otherwise.
valueMissingThe control is suffering from being missing.
typeMismatchThe control is suffering from a type mismatch.
patternMismatchThe control is suffering from a pattern mismatch.
tooLongThe control is suffering from being too long.
rangeUnderflowThe control is suffering from an underflow.
rangeOverflowThe control is suffering from an overflow.
stepMismatchThe control is suffering from a step mismatch.
customErrorThe control is suffering from a custom error.
validNone of the other conditions are true.
When the checkValidity()
  method is invoked, if the element is a candidate for
  constraint validation and does not satisfy its constraints, the user
  agent must fire a simple event named invalid that is cancelable (but in this
  case has no default action) at the element and return
  false. Otherwise, it must only return true without doing anything
  else.
The validationMessage
  attribute must return the empty string if the element is not a
  candidate for constraint validation or if it is one but
  it satisfies its constraints;
  otherwise, it must return a suitably localized message that the user
  agent would show the user if this were the only form control with a
  validity constraint problem. If the user agent would not actually
  show a textual message in such a situation (e.g. it would show a
  graphical cue instead), then the attribute must return a suitably
  localized message that expresses (one or more of) the validity
  constraint(s) that the control does not satisfy. If the element is a
  candidate for constraint validation and is
  suffering from a custom error, then the custom
  validity error message should be present in the return
  value.
Servers should not rely on client-side validation. Client-side validation can be intentionally bypassed by hostile users, and unintentionally bypassed by users of older user agents or automated tools that do not implement these features. The constraint validation features are only intended to improve the user experience, not to provide any kind of security mechanism.
This section is non-normative.
When a form is submitted, the data in the form is converted into the structure specified by the enctype, and then sent to the destination specified by the action using the given method.
For example, take the following form:
<form action="/find.cgi" method=get> <input type=text name=t> <input type=search name=q> <input type=submit> </form>
If the user types in "cats" in the first field and "fur" in the
  second, and then hits the submit button, then the user agent will
  load /find.cgi?t=cats&q=fur.
On the other hand, consider this form:
<form action="/find.cgi" method=post enctype="multipart/form-data"> <input type=text name=t> <input type=search name=q> <input type=submit> </form>
Given the same user input, the result on submission is quite different: the user agent instead does an HTTP POST to the given URL, with as the entity body something like the following text:
------kYFrd4jNJEgCervE Content-Disposition: form-data; name="t" cats ------kYFrd4jNJEgCervE Content-Disposition: form-data; name="q" fur ------kYFrd4jNJEgCervE--
User agents may establish a button in each form as being the
  form's default button. This should be the first submit button in tree
  order whose form owner is that form
  element, but user agents may pick another button if another would be
  more appropriate for the platform. If the platform supports letting
  the user submit a form implicitly (for example, on some platforms
  hitting the "enter" key while a text field is focused implicitly
  submits the form), then doing so must cause the form's default
  button's activation behavior, if any, to be
  run.
Consequently, if the default button is disabled, the form is not submitted when such an implicit submission mechanism is used. (A button has no activation behavior when disabled.)
If the form has no submit
  button, then the implicit submission mechanism must just
  submit the
  form element from the form element
  itself.
ISSUE-138 (mutate-action) blocks progress to Last Call
When a form element form is submitted from an element submitter (typically a button), optionally with a
  scripted-submit flag set, the user agent must
  run the following steps:
Let form document be the form's Document.
If form
   document has no associated browsing context or
   its browsing context had its sandboxed forms
   browsing context flag set when the Document was
   created, then abort these steps without doing anything.
Let form browsing context be the browsing context of form document.
If form is already being submitted
   (i.e. the form was submitted again while processing
   the events fired from the next two steps, probably from a script
   redundantly calling the submit() method on form), then abort these steps. This doesn't affect
   the earlier instance of this algorithm.
If the scripted-submit flag is not set, and the submitter element's no-validate state is false, then interactively validate the constraints of form and examine the result: if the result is negative (the constraint validation concluded that there were invalid fields and probably informed the user of this) then abort these steps.
If the scripted-submit flag is not set,
   then fire a simple event that is cancelable named
   submit, at form. If the event's default action is prevented
   (i.e. if the event is canceled) then abort these steps. Otherwise,
   continue (effectively the default action is to perform the
   submission).
Let controls be a list of all the submittable elements whose form owner is form, in tree order.
Let the form data set be a list of name-value-type tuples, initially empty.
Constructing the form data set. For each element field in controls, in tree order, run the following substeps:
If any of the following conditions are met, then skip these substeps for this element:
datalist element ancestor.input element whose type attribute is in the Checkbox state and
       whose checkedness is
       false.input element whose type attribute is in the Radio Button state and
       whose checkedness is
       false.input element whose type attribute is in the Image Button state, and
       either the field element does not have a
       name attribute specified, or
       its name attribute's value is
       the empty string.object element that is not using a
       plugin.Otherwise, process field as follows:
Let type be the value of the type IDL attribute of field.
If the field element is an
      input element whose type attribute is in the Image Button state,
      then run these further nested substeps:
If the field element has a name attribute specified and value
       is not the empty string, let name be that
       value followed by a single U+002E FULL STOP character
       (.). Otherwise, let name be the empty
       string.
Let namex be the string consisting of the concatenation of name and a single U+0078 LATIN SMALL LETTER X character (x).
Let namey be the string consisting of the concatenation of name and a single U+0079 LATIN SMALL LETTER Y character (y).
The field element is submitter, and before this algorithm was invoked the user indicated a coordinate. Let x be the x-component of the coordinate selected by the user, and let y be the y-component of the coordinate selected by the user.
Append an entry to the form data set with the name namex, the value x, and the type type.
Append an entry to the form data set with the name namey and the value y, and the type type.
Skip the remaining substeps for this element: if there are any more elements in controls, return to the top of the constructing the form data set step, otherwise, jump to the next step in the overall form submission algorithm.
Let name be the value of the field element's name attribute.
If the field element is a
     select element, then for each option
     element in the select element whose selectedness is true,
     append an entry to the form data set with the
     name as the name, the value of the
     option element as the value, and type as the type.
Otherwise, if the field element is an
      input element whose type attribute is in the Checkbox state or the
      Radio Button state,
      then run these further nested substeps:
If the field element has a value attribute specified, then
       let value be the value of that attribute;
       otherwise, let value be the string
       "on".
Append an entry to the form data set with name as the name, value as the value, and type as the type.
Otherwise, if the field element is an
     input element whose type attribute is in the File Upload state, then for
     each file selected in the
     input element, append an entry to the form data set with the name as
     the name, the file (consisting of the name, the type, and the
     body) as the value, and type as the type. If
     there are no selected files,
     then append an entry to the form data set
     with the name as the name, the empty string
     as the value, and application/octet-stream as the
     type.
Otherwise, if the field element is an
     object element: try to obtain a form submission
     value from the plugin,
     and if that is successful, append an entry to the form data set with name as the
     name, the returned form submission value as the value, and the
     string "object" as the type.
Otherwise, append an entry to the form data set with name as the name, the value of the field element as the value, and type as the type.
If the element has a form control dirname attribute, and that attribute's
      value is not the empty string, then run these substeps:
Let dirname be the value of the
       element's dirname attribute.
Let dir be the string "ltr" if the directionality of the
       element is 'ltr', and "rtl" otherwise (i.e. when the
       directionality of the element is 'rtl').
Append an entry to the form data set
       with dirname as the name, dir as the value, and the string "direction" as the type.
An element can only have a form control
      dirname attribute if it is a
      textarea element or an input element
      whose type attribute is in
      either the Text state
      or the Search
      state.
Let action be the submitter element's action.
If action is the empty string, let action be the document's address of the form document.
This step is a willful violation of RFC 3986, which would require base URL processing here. This violation is motivated by a desire for compatibility with legacy content. [RFC3986]
Resolve the URL action, relative to the submitter element. If this fails, abort these steps. Otherwise, let action be the resulting absolute URL.
Let scheme be the <scheme> of the resulting absolute URL.
Let enctype be the submitter element's enctype.
Let method be the submitter element's method.
Let target be the submitter element's target.
If the user indicated a specific browsing context to use when submitting the form, then let target browsing context be that browsing context. Otherwise, apply the rules for choosing a browsing context given a browsing context name using target as the name and form browsing context as the context in which the algorithm is executed, and let target browsing context be the resulting browsing context.
If target browsing context was created in the previous step, or if the form document has not yet completely loaded, then let replace be true. Otherwise, let it be false.
Select the appropriate row in the table below based on the value of scheme as given by the first cell of each row. Then, select the appropriate cell on that row based on the value of method as given in the first cell of each column. Then, jump to the steps named in that cell and defined below the table.
| GET | POST | |
|---|---|---|
| http | Mutate action | Submit as entity body | 
| https | Mutate action | Submit as entity body | 
| ftp | Get action | Get action | 
| javascript | Get action | Get action | 
| data | Get action | Post to data: | 
| mailto | Mail with headers | Mail as body | 
If scheme is not one of those listed in this table, then the behavior is not defined by this specification. User agents should, in the absence of another specification defining this, act in a manner analogous to that defined in this specification for similar schemes.
The behaviors are as follows:
Let query be the result of encoding the
      form data set using the application/x-www-form-urlencoded encoding
      algorithm, interpreted as a US-ASCII string.
Let destination be a new URL that is equal to the action except that its <query> component is replaced by query (adding a U+003F QUESTION MARK character (?) if appropriate).
Navigate target browsing context to destination. If replace is true, then target browsing context must be navigated with replacement enabled.
Let entity body be the result of encoding the form data set using the appropriate form encoding algorithm.
Let MIME type be determined as follows:
application/x-www-form-urlencodedapplication/x-www-form-urlencoded".multipart/form-datamultipart/form-data".text/plaintext/plain".Otherwise, navigate target browsing context to action using the HTTP method given by method and with entity body as the entity body, of type MIME type. If replace is true, then target browsing context must be navigated with replacement enabled.
Navigate target browsing context to action. If replace is true, then target browsing context must be navigated with replacement enabled.
Let data be the result of encoding the form data set using the appropriate form encoding algorithm.
If action contains the string "%%%%" (four U+0025 PERCENT SIGN characters),
      then %-escape all bytes in data that, if
      interpreted as US-ASCII, do not match the unreserved production in the URI Generic Syntax,
      and then, treating the result as a US-ASCII string, further
      %-escape all the U+0025 PERCENT SIGN characters in the resulting
      string and replace the first occurrence of "%%%%" in action with the
      resulting double-escaped string. [RFC3986]
Otherwise, if action contains the string
      "%%" (two U+0025 PERCENT SIGN characters
      in a row, but not four), then %-escape all characters in data that, if interpreted as US-ASCII, do not
      match the unreserved production in the URI
      Generic Syntax, and then, treating the result as a US-ASCII
      string, replace the first occurrence of "%%" in action with the
      resulting escaped string. [RFC3986]
Navigate target
      browsing context to the potentially modified action (which will be a data: URL). If replace is true, then target
      browsing context must be navigated with replacement
      enabled.
Let headers be the resulting encoding the
      form data set using the application/x-www-form-urlencoded encoding
      algorithm, interpreted as a US-ASCII string.
Replace occurrences of U+002B PLUS SIGN characters (+) in
      headers with the string "%20".
Let destination consist of all the characters from the first character in action to the character immediately before the first U+003F QUESTION MARK character (?), if any, or the end of the string if there are none.
Append a single U+003F QUESTION MARK character (?) to destination.
Append headers to destination.
Navigate target browsing context to destination. If replace is true, then target browsing context must be navigated with replacement enabled.
Let body be the resulting encoding the
      form data set using the appropriate
      form encoding algorithm and then %-escaping all the bytes
      in the resulting byte string that, when interpreted as US-ASCII,
      do not match the unreserved production in
      the URI Generic Syntax. [RFC3986]
Let destination have the same value as action.
If destination does not contain a U+003F QUESTION MARK character (?), append a single U+003F QUESTION MARK character (?) to destination. Otherwise, append a single U+0026 AMPERSAND character (&).
Append the string "body=" to destination.
Append body, interpreted as a US-ASCII string, to destination.
Navigate target browsing context to destination. If replace is true, then target browsing context must be navigated with replacement enabled.
The appropriate form encoding algorithm is determined as follows:
application/x-www-form-urlencodedapplication/x-www-form-urlencoded encoding
     algorithm.multipart/form-datamultipart/form-data encoding
     algorithm.text/plaintext/plain encoding
     algorithm.The application/x-www-form-urlencoded encoding
  algorithm is as follows:
Let result be the empty string.
If the form element has an accept-charset attribute,
    then, taking into account the characters found in the form data set's names and values, and the character
    encodings supported by the user agent, select a character encoding
    from the list given in the form's accept-charset attribute
    that is an ASCII-compatible character encoding. If
    none of the encodings are supported, or if none are listed, then
    let the selected character encoding be UTF-8.
Otherwise, if the document's character encoding is an ASCII-compatible character encoding, then that is the selected character encoding.
Otherwise, let the selected character encoding be UTF-8.
Let charset be the preferred MIME name of the selected character encoding.
For each entry in the form data set, perform these substeps:
If the entry's name is "_charset_"
     and its type is "hidden", replace its value
     with charset.
If the entry's type is "file",
     replace its value with the file's filename only.
For each character in the entry's name and value that cannot be expressed using the selected character encoding, replace the character by a string consisting of a U+0026 AMPERSAND character (&), a U+0023 NUMBER SIGN character (#), one or more characters in the range U+0030 DIGIT ZERO (0) to U+0039 DIGIT NINE (9) representing the Unicode code point of the character in base ten, and finally a U+003B SEMICOLON character (;).
For each character in the entry's name and value, apply the appropriate subsubsteps from the following list:
Replace the character with a string formed as follows:
Let s be an empty string.
For each byte b of the character when expressed in the selected character encoding in turn, run the appropriate subsubsubstep from the list below:
Append to s the Unicode character with the codepoint equal to the byte.
Append to the string a U+0025 PERCENT SIGN character (%) followed by two characters in the ranges U+0030 DIGIT ZERO (0) to U+0039 DIGIT NINE (9) and U+0041 LATIN CAPITAL LETTER A to U+0046 LATIN CAPITAL LETTER F representing the hexadecimal value of the byte (zero-padded if necessary).
Leave the character as is.
If the entry's name is "isindex",
     its type is "text", and this is the first
     entry in the form data set, then append the
     value to result and skip the rest of the
     substeps for this entry, moving on to the next entry, if any, or
     the next step in the overall algorithm otherwise.
If this is not the first entry, append a single U+0026 AMPERSAND character (&) to result.
Append the entry's name to result.
Append a single U+003D EQUALS SIGN character (=) to result.
Append the entry's value to result.
Encode result as US-ASCII and return the resulting byte stream.
The multipart/form-data encoding
  algorithm is as follows:
Let result be the empty string.
If the form element has an accept-charset attribute,
    then, taking into account the characters found in the form data set's names and values, and the character
    encodings supported by the user agent, select a character encoding
    from the list given in the form's accept-charset attribute
    that is an ASCII-compatible character encoding. If
    none of the encodings are supported, or if none are listed, then
    let the selected character encoding be UTF-8.
Otherwise, if the document's character encoding is an ASCII-compatible character encoding, then that is the selected character encoding.
Otherwise, let the selected character encoding be UTF-8.
Let charset be the preferred MIME name of the selected character encoding.
For each entry in the form data set, perform these substeps:
If the entry's name is "_charset_"
     and its type is "hidden", replace its value
     with charset.
For each character in the entry's name and value that cannot be expressed using the selected character encoding, replace the character by a string consisting of a U+0026 AMPERSAND character (&), a U+0023 NUMBER SIGN character (#), one or more characters in the range U+0030 DIGIT ZERO (0) to U+0039 DIGIT NINE (9) representing the Unicode code point of the character in base ten, and finally a U+003B SEMICOLON character (;).
Encode the (now mutated) form data set
    using the rules described by RFC 2388, Returning Values from
    Forms: multipart/form-data, and
    return the resulting byte stream. [RFC2388]
Each entry in the form data set is a field, the name of the entry is the field name and the value of the entry is the field value.
The order of parts must be the same as the order of fields in the form data set. Multiple entries with the same name must be treated as distinct fields.
The parts of the generated multipart/form-data resource that correspond to
    non-file fields must not have a Content-Type header
    specified. Their names and values must be encoded using the
    character encoding selected above (field names in particular do
    not get converted to a 7-bit safe encoding as suggested in RFC
    2388).
The text/plain encoding
  algorithm is as follows:
Let result be the empty string.
If the form element has an accept-charset attribute,
    then, taking into account the characters found in the form data set's names and values, and the character
    encodings supported by the user agent, select a character encoding
    from the list given in the form's accept-charset attribute.
    If none of the encodings are supported, or if none are listed,
    then let the selected character encoding be UTF-8.
Otherwise, the selected character encoding is the document's character encoding.
Let charset be the preferred MIME name of the selected character encoding.
If the entry's name is "_charset_" and its type is
   "hidden", replace its value with charset.
If the entry's type is "file", replace
   its value with the file's filename only.
For each entry in the form data set, perform these substeps:
Append the entry's name to result.
Append a single U+003D EQUALS SIGN character (=) to result.
Append the entry's value to result.
Append a U+000D CARRIAGE RETURN (CR) U+000A LINE FEED (LF) character pair to result.
Encode result using the selected character encoding and return the resulting byte stream.
When a form element form is reset, the user agent must
  fire a simple event named reset, that is cancelable, at form, and then, if that event is not canceled, must
  invoke the reset
  algorithm of each resettable
  element whose form owner is form, and broadcast formchange events from form.
Each resettable element
  defines its own reset
  algorithm. Changes made to form controls as part of these
  algorithms do not count as changes caused by the user (and thus,
  e.g., do not cause input events to
  fire).
When the user agent is to broadcast forminput events or
  broadcast formchange
  events from a form element form, it must run the following steps:
Let controls be a list of all the resettable elements whose form owner is form.
forminput events, let event name be forminput. Otherwise the user agent
   was to broadcast formchange events; let event name be formchange.For each element in controls, in tree order, fire a simple event named event name at the element.