Movatterモバイル変換


[0]ホーム

URL:


  1. Web
  2. Web APIs
  3. HTMLFormElement
  4. elements

HTMLFormElement: elements property

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since ⁨July 2015⁩.

Theelements property of theHTMLFormElement interface returns anHTMLFormControlsCollection listing all the listed form controls associated with the<form> element.

You can access a particular form control in the returned collection by using either an index or the element'sname orid attributes.

Prior to HTML 5, the returned object was anHTMLCollection, on whichHTMLFormControlsCollection is based.

Independently, you can obtain just the number of associated form controls using thelength property. You can get a list of all of the forms contained within a given document using the document'sforms property.

Value

AnHTMLFormControlsCollection containing all non-image controls associated with the form.This is a live collection; if form controls are associated with or disassociated from the form, this collection will update to reflect the change.

The form controls in the returned collection are in the same order in which they appear in the document by following a preorder, depth-first traversal of the tree.This is calledtree order.

Only the following form controls are returned:

Examples

Quick syntax example

In this example, we see how to obtain the list of form controls as well as how to access its members by index and by name or ID.

html
<form>  <label>    Username:    <input type="text" name="username" />  </label>  <label>    Full name:    <input type="text" name="full-name" />  </label>  <label>    Password:    <input type="password" name="password" />  </label></form>
js
const inputs = document.getElementById("my-form").elements;const inputByIndex = inputs[0];const inputByName = inputs["username"];

Associated form controls

This example demonstrates how theHTMLFormControlsCollection contains the form controls associated with the form, rather than the controls physically nested in the<form>.

The first form is full, with four form controls: one<fieldset> and three<input> elements. The<legend> and<label> elements are not listed form controls. The second form is sparse, with only one nested form control: a single<object> element. All the form controls in the full form are associated with the sparse form via theirform attribute.

html
<form>  This form looks full, but it has no associated form controls  <fieldset form="sparseForm">    <legend>This is a legend</legend>    <label>A form control: <input form="sparseForm" /></label>    <label>Another form control: <input form="sparseForm" /></label>    <label>Yet another form control: <input form="sparseForm" /></label>  </fieldset></form><form>  <object data="lone-form-control.jpg">Lone form control</object></form>

We use theelements property to get theHTMLFormControlsCollection for each form.

js
const sparse = document.getElementById("sparseForm").elements;const full = document.getElementById("fullForm").elements;

The collection includes the form element's associated form controls, meaning all the<button>,<fieldset>,<input>,<object>,<output>,<select>,<textarea>, and form-associated custom elements associated with the form, even if those elements are nested in another form, or not nested in any form.

js
console.log(`sparse form: ${sparse.length}`); // sparse form: 5console.log(`full form: ${full.length}`); // full form: 0

The collection's form controls are in the same order in which they appear in the document.

js
console.log(`first member: ${sparse[0].tagName}`); // first member: FIELDSETconsole.log(`last member: ${sparse[sparse.length - 1].tagName}`); // last member: OBJECT

Accessing form controls

This example gets the form's element list, then iterates over the list, looking for<input> elements of type"text" so that some form of processing can be performed on them.

js
const inputs = document.getElementById("my-form").elements;// Iterate over the form controlsfor (const input of inputs) {  if (input.nodeName === "INPUT" && input.type === "text") {    // Update text input    input.value = input.value.toLocaleUpperCase();  }}

Disabling form controls

js
const inputs = document.getElementById("my-form").elements;// Iterate over the form controlsfor (const input of inputs) {  // Disable all form controls  input.setAttribute("disabled", "");}

Specifications

Specification
HTML
# dom-form-elements-dev

Browser compatibility

Help improve MDN

Learn how to contribute

This page was last modified on byMDN contributors.


[8]ページ先頭

©2009-2025 Movatter.jp