From 9d35f59c63e60c74d1f05586731159f1cc6099f8 Mon Sep 17 00:00:00 2001
From: Kent Tamura The form-associated elements fall into several
@@ -42990,6 +42993,7 @@ interface HTMLTableCellElement : HTMLElement {
Some submittable elements can be, depending on their
@@ -43030,6 +43035,7 @@ interface HTMLTableCellElement : HTMLElement {
FormData
interfaceFormDataEntryValue
+ typeselect
textarea
img
output
select
textarea
object
select
textarea
output
select
textarea
progress
select
textarea
label
elements, in tree order, whose labeled
control is the element in question. The labels
IDL attribute of labelable elements and input
elements, on getting,
+ data-x="category-label">labelable elements that are not form-associated custom elements, and the labels
IDL attribute of input
elements, on getting,
must return that NodeList
object, and that same value must always be returned, unless
this element is an input
element whose type
attribute is in the Hidden state, in which case it
must instead return null.
Form-associated custom elements don't have
+ a labels
IDL attribute. Instead, their
+ ElementInternals
object has a labels
IDL attribute. On getting, it must throw
+ a "NotSupportedError
" DOMException
if the target element is not a form-associated custom
+ element. Otherwise, it must return that NodeList
object, and that same value
+ must always be returned.
This (non-conforming) example shows what happens to the Listed form-associated elements have a Form-associated custom elements don't have
+ NodeList
and what labels
returns when an input
element has its HTMLLegendElement : HTMLElement {
form
- IDL attribute, which, on getting, must return the element's form owner, or null if
- there isn't one.form
IDL attribute, which, on getting, must return
+ the element's form owner, or null if there isn't one.
+
+ form
IDL attribute. Instead, their
+ ElementInternals
object has a form
IDL attribute. On getting, it must throw a
+ "NotSupportedError
" DOMException
if the target element is not a form-associated custom
+ element. Otherwise, it must return the element's form owner, or null if there
+ isn't one.
button
, input
, select
, or
- textarea
element, and the disabled
attribute
- is specified on this element (regardless of its value).button
, input
, select
,
+ textarea
, or form-associated custom element, and the disabled
attribute is specified on this element (regardless of
+ its value).fieldset
element whose disabled
attribute is specified, and is not a
@@ -55501,9 +55530,13 @@ control.setSelectionRange(oldStart + prefix.length, oldEnd + prefix.length, oldD
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.
setCustomValidity()
method, except for
+ form-associated custom elements. Form-associated custom elements can have a
+ custom validity error message set via their ElementInternals
object's
+ setValidity()
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 @@ -55514,64 +55547,119 @@ control.setSelectionRange(oldStart + prefix.length, oldEnd + prefix.length, oldD
When a control has no value but has a required
attribute (input
required
, textarea
required
); or, more complicated rules for
- select
elements and controls in radio button
- groups, as specified in their sections.
When a control has no value but has a required
attribute (input
required
, textarea
required
); or, more complicated rules for
+ select
elements and controls in radio button
+ groups, as specified in their sections.
When the setValidity()
method sets
+ valueMissing
flag to true for a
+ form-associated custom element.
When a control that allows arbitrary user input has a value that is not in the correct syntax (E-mail, URL). -
When a control that allows arbitrary user input has a value that is not in the correct syntax (E-mail, URL). +
+ +When the setValidity()
method sets
+ typeMismatch
flag to true for a
+ form-associated custom element.
When a control has a value that doesn't satisfy the
- pattern
attribute.
When a control has a value that doesn't satisfy the
+ pattern
attribute.
When the setValidity()
method sets
+ patternMismatch
flag to true for a
+ form-associated custom element.
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 long for the
+ form control maxlength
attribute
+ (input
maxlength
, textarea
+ maxlength
).
When the setValidity()
method sets
+ tooLong
flag to true for a
+ form-associated custom element.
When a control has a value that is too short for the
- form control minlength
attribute
- (input
minlength
, textarea
- minlength
).
When a control has a value that is too short for the
+ form control minlength
attribute
+ (input
minlength
, textarea
+ minlength
).
When the setValidity()
method sets
+ tooShort
flag to true for a
+ form-associated custom element.
When a control has a value that is not the empty
- string and is too low for the min
attribute.
When a control has a value that is not the empty
+ string and is too low for the min
attribute.
When the setValidity()
method sets
+ rangeUnderflow
flag to true for a
+ form-associated custom element.
When a control has a value that is not the empty
- string and is too high for the max
attribute.
When a control has a value that is not the empty
+ string and is too high for the max
attribute.
When the setValidity()
method sets
+ rangeOverflow
flag to true for a
+ form-associated custom element.
When a control has a value that doesn't fit the
- rules given by the step
attribute.
When a control has a value that doesn't fit the
+ rules given by the step
attribute.
When the setValidity()
method sets
+ stepMismatch
flag to true for a
+ form-associated custom element.
When a control has incomplete input and the user agent does not think the user ought to - be able to submit the form in its current state.
When a control has incomplete input and the user agent does not think the user ought to + be able to submit the form in its current state.
+ +When the setValidity()
method sets
+ badInput
flag to true for a form-associated custom element.
+
When a control's custom validity error message (as set by the element's
- setCustomValidity()
method) is not the empty
- string.
setCustomValidity()
method or
+ ElementInternals
's setValidity()
method) is
+ not the empty string.
@@ -55659,16 +55747,29 @@ control.setSelectionRange(oldStart + prefix.length, oldEnd + prefix.length, oldD
If the result was positive, then return that result.
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.
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. For + elements that are form-associated custom + elements, user agents should use their validation + anchor instead, for the purposes of these actions.
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.
The willValidate
attribute
+ of ElementInternals
interface, on getting, must throw a
+ "NotSupportedError
" DOMException
if the
+ target element is not a
+ form-associated custom element. Otherwise, it must return true if the
+ target element is a
+ candidate for constraint validation, and false otherwise.
The setCustomValidity(message)
method, when
invoked, must set the custom validity error message to message.
ValidityState
object that represents the validity states of this
element. This object is live.
+ The validity
attribute of
+ ElementInternals
interface, on getting, must throw a
+ "NotSupportedError
" DOMException
if the
+ target element is not a
+ form-associated custom element. Otherwise, it must return a
+ ValidityState
object that represents the validity states of the
+ target element. This object is live.
[Exposed=Window]
interface ValidityState {
readonly attribute boolean valueMissing;
@@ -55921,17 +56038,16 @@ interface ValidityState {
- The checkValidity()
method, when
- invoked, must run these steps:
+ The check validity steps for an element element are:
-
-
If this element is a candidate for constraint validation and does not satisfy its constraints, then:
+ If element is a candidate for constraint validation and does not
+ satisfy its constraints, then:
Fire an event named invalid
at this element, with the invalid
at element, with the cancelable
attribute initialized to true (though canceling
has no effect).
@@ -55941,27 +56057,42 @@ interface ValidityState {
Return true.
- The reportValidity()
method, when
- invoked, must run these steps:
+
The checkValidity()
method, when
+ invoked, must run the check validity steps on this element.
+
+ The checkValidity()
method
+ of the ElementInternals
interface must run these steps:
+
+
+ Let element be this ElementInternals
's target element.
+
+ If element is not a form-associated custom element, then throw a
+ "NotSupportedError
" DOMException
.
+
+ Run the check validity steps on element.
+
+
+ The report validity steps for an element element are:
-
-
If this element is a candidate for constraint validation and does not satisfy its constraints, then:
+
If element is a candidate for constraint validation and does not
+ satisfy its constraints, then:
Let report be the result of firing an
- event named invalid
at this element, with the cancelable
attribute initialized to true.
+ event named invalid
at element, with the
+ cancelable
attribute initialized to true.
If report is true, then report the problems with the constraints of this
element to the user. When reporting the problem with the constraints to the user, the user
- agent may run the focusing steps for this element, and may change the scrolling
- position of the document, or perform some other action that brings this element to the user's
- attention. User agents may report more than one constraint violation, if this element suffers
- from multiple problems at once. If this element is not being rendered, then the
- user agent may, instead of notifying the user, report the error for the
- running script.
+ agent may run the focusing steps for element, and may change the
+ scrolling position of the document, or perform some other action that brings element
+ to the user's attention. User agents may report more than one constraint violation, if
+ element suffers from multiple problems at once. If element is not
+ being rendered, then the user agent may, instead of notifying the user,
+ report the error for the running script.
Return false.
@@ -55969,6 +56100,22 @@ interface ValidityState {
Return true.
+ The reportValidity()
method, when
+ invoked, must run the report validity steps on this element.
+
+ The reportValidity()
+ method of the ElementInternals
interface must run these steps:
+
+
+ Let element be this ElementInternals
's target element.
+
+ If element is not a form-associated custom element, then throw a
+ "NotSupportedError
" DOMException
.
+
+ Run the report validity steps on element.
+
+
The validationMessage
attribute's
getter must run these steps:
@@ -56546,12 +56693,6 @@ fur
data-x="attr-input-type-radio">Radio Button state and whose checkedness is false.
-
- The field element is not an
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.
-
- The field element is an
object
element that is not using
a plugin.
@@ -56593,6 +56734,15 @@ fur
If the field is a form-associated custom element, then perform + the entry construction algorithm given + field and entry list, then continue.
If either the field element does not have a
+ name
attribute specified, or its
+ name
attribute's value is the empty string, then
+ continue.
Let name be the value of the field element's
name
attribute.
Adding a static formAssociated
property, with a true value, makes an
+ autonomous custom element a form-associated custom element. The
+ ElementInternals
interface helps you to implement functions and properties common
+ to form control elements.
class MyCheckbox extends HTMLElement {
+ static get formAssociated() { return true; }
+
+ constructor() {
+ super();
+ this._internals = this.attachInternals();
+ this._checked = false;
+ this.addEventListener('click', this._onClick.bind(this));
+ }
+
+ get form() { return this._internals.form; }
+ get name() { return this.getAttribute('name'); }
+ get type() { return this.localName; }
+
+ get checked() { return this._checked; }
+ set checked(flag) {
+ this._checked = !!flag;
+ this._internals.setFormValue(this._checked ? 'on' : null);
+ }
+
+ _onClick(event) {
+ this.checked = !this._checked;
+ }
+}
+customElements.define('my-checkbox', MyCheckbox);
+
+ You can use the custom element my-checkbox
like a built-in
+ form-associated element. For example, putting it in form
or label
+ associates the my-checkbox
element with them, and submitting the
+ form
will send data provided by my-checkbox
implementation.
+
<form action="..." method="...">
+ <label><my-checkbox name="agreed"></my-checkbox> I read the agreement.</label>
+ <input type="submit">
+</form>
+
+
+
is
attributeform
, for form-associated custom elementsdisabled
, for form-associated custom elementsreadonly
, for form-associated custom elementsname
, for form-associated custom elementsHTMLElement
)An autonomous custom element is called a form-associated custom element + if the element is associated with a custom element definition whose form-associated field is set to + true.
+ +The name
attribute represents the form-associated
+ custom element's name. The disabled
attribute is
+ used to make the form-associated custom element non-interactive and to prevent its
+ submission value from being submitted. The form
attribute is used to explicitly associate the
+ form-associated custom element with its form owner.
The readonly
attribute of form-associated custom elements specifies that the
+ element is barred from constraint validation. User agents don't provide any other
+ behavior for the attribute.
Constraint validation: If the readonly
attribute is specified on a form-associated
+ custom element, the element is barred from constraint validation.
The reset algorithm for form-associated custom elements is to enqueue
+ a custom element callback reaction with the element, callback name "formResetCallback
", and an empty argument list.
A valid custom element name is a sequence of characters name that meets all of the following requirements:
@@ -66763,10 +66993,13 @@ document.body.append(parent);connectedCallback
",
- "disconnectedCallback
", "adoptedCallback
", and
- "attributeChangedCallback
". The corresponding values are either a Web IDL
- Function
callback function type value, or null. By default the
- value of each entry is null.disconnectedCallback
", "adoptedCallback
",
+ "attributeChangedCallback
",
+ "formAssociatedCallback
",
+ "formDisabledCallback
",
+ "formResetCallback
", and "formStateRestoreCallback
".
+ The corresponding values are either a Web IDL Function
+ callback function type value, or null. By default the value of each entry is null.
attachInternals()
.
@@ -66956,6 +67195,8 @@ dictionary ElementDefinitionOptions {
Set this CustomElementRegistry
's element definition is running
flag.
Let formAssociated be false.
Let disableInternals be false.
Let disableShadow be false. @@ -67027,6 +67268,31 @@ dictionary ElementDefinitionOptions {
Set disableShadow to true if disabledFeaturesSequence
contains "shadow
".
Let formAssociatedValue be Get( + constructor, "formAssociated"). Rethrow any exceptions.
Set formAssociated to the result of
+ converting formAssociatedValue to a
+ boolean
. Rethrow any exceptions from the conversion.
If formAssociated is true, for each of
+ "formAssociatedCallback
", "formResetCallback
",
+ "formDisabledCallback
", and
+ "formStateRestoreCallback
" callbackName:
Let callbackValue be Get(prototype, + callbackName). Rethrow any exceptions.
If callbackValue is not undefined, then set the value of the entry in
+ lifecycleCallbacks with key callbackName to the result of converting callbackValue to the Web IDL
+ Function
callback type. Rethrow any exceptions from the
+ conversion.
Then, perform the following substep, regardless of whether the above steps threw an exception
@@ -67049,7 +67315,9 @@ dictionary ElementDefinitionOptions {
data-x="concept-custom-element-definition-observed-attributes">observed attributes
observedAttributes, lifecycle callbacks
- lifecycleCallbacks, lifecycleCallbacks,
+ form-associated
+ formAssociated, disable internals
disableInternals, and disable shadow
@@ -67320,6 +67588,21 @@ customElements.define("x-foo", class extends HTMLElement {
+ If element is a form-associated custom element, then: Reset the form owner of element. If element is
+ associated with a If element is disabled, then
+ enqueue a custom element callback reaction with element, callback name
+ " Set element's custom element state to "
+
+ form
element, then
+ enqueue a custom element callback reaction with element, callback
+ name "formAssociatedCallback
", and « the associated form
+ ».formDisabledCallback
" and « true ».custom
".
When the user agent resets the form owner of a
+ form-associated custom element and doing so changes the form owner, its formAssociatedCallback
is called, given the new form owner (or null if no owner)
+ as an argument.
When the form owner of a form-associated custom element is reset, its formResetCallback
is
+ called.
When the disabled state of a
+ form-associated custom element is changed, its formDisabledCallback
is called, given the new state as an
+ argument.
When user agent updates a form-associated custom element's value on behalf of
+ a user, its formStateRestoreCallback
is called, given the new value and a
+ string indicating a reason, "restore
" or "autocomplete
", as arguments.
We call these reactions collectively custom
@@ -67639,10 +67941,112 @@ customElements.define("x-foo", class extends HTMLElement {
Sets both the state and
+ submission value of internals's
+ target element to value. If value is null, the element won't participate in form submission. Sets the submission value of
+ internals's target element to
+ value, and its state to state. If value is null, the element won't participate in form submission. Returns the form owner of internals's
+ target element. Marks internals's target element as
+ suffering from the constraints indicated by the flags argument, and sets the element's
+ validation message to message. If anchor is specified, the user agent might
+ use it to indicate problems with the constraints of internals's target element when the form owner is validated
+ interactively or Marks internals's target element as
+ satisfying its constraints. Returns true if internals's
+ target element will be validated when the form is
+ submitted; false otherwise. Returns the Returns the error message that would be shown to the user if internals's
+ target element was to be checked for validity. Returns true if internals's
+ target element has no validity problems; false otherwise.
+ Fires an Returns true if internals's
+ target element has no validity problems; otherwise,
+ returns false, fires an Returns a Each Each form-associated custom element has submission value. It is used to provide one or more
+ entries on form submission, and
+ The initial value of submission value is null, and
+ submission value can be null, a string, a
+ Each form-associated custom element has state.
+ It is information with which the user agent can restore a user's input for the element.
+ The initial value of state is null, and state can be null, a string, a The When the user agent believes it is a good idea to restore a form-associated custom
+ element's state, for example after navigation or
+ restarting the user agent, they may enqueue a custom element callback reaction with
+ that element, callback name " If the user agent has a form-filling assist feature, then when the feature is invoked,
+ it may enqueue a custom element callback reaction with
+ a form-associated custom element, callback name
+ " In general, the state is information specified by a user, and
+ the submission value is a value after canonicalization
+ or sanitization, suitable for submission to the server. The following examples makes this
+ concrete: Suppose that we have a form-associated custom element which asks a
+ user to specify a date. The user specifies "3/15/2019", but the control wishes to
+ submit Suppose you develop a custom element emulating a the behavior of the existing
+ checkbox The Let element be this If element is not a form-associated custom element, then throw a
+ " Set target element's submission value to value if value is
+ not a If the state argument of the function is omitted, set element's
+ state to its submission
+ value.
+
+ Otherwise, if state is a Otherwise, set element's state to
+ state. Each form-associated custom element has validity flags named
+ Each form-associated custom element has a
+ validation message string. It is the empty string
+ initially. Each form-associated custom element has a
+ validation anchor element. It is null initially. The Let element be this If element is not a form-associated custom element, then throw a
+ " If flags contains one or more true values and message is not given
+ or is the empty string, then throw a For each entry flag → value of flags, set
+ element's validity flag with the name flag to value. Set element's validation message
+ to the empty string if message is not given or all of element's validity
+ flags are false, or to message otherwise. If element's Set element's validation anchor to
+ null if anchor is not given. Otherwise, if anchor is not a
+ shadow-including descendant of element, then throw a
+ " The When entry construction algorithm for a
+ form-associated custom element is invoked, given an element element and a
+ list entry list, run the following steps: If element's submission value is a
+ list of entries, then append each item of element's submission value to entry list, and return. In this case, user agent does not refer to the
+ If the element does not have a If the element's submission value is not
+ null, append an entry to entry list with the
+ This definition is used to determine what elements :enabled pseudo-class must match any
-
+ [Exposed=Window]
interface ElementInternals {
-
+ // Form-associated custom elements
+
+ void setFormValue((File or USVString or FormData)? value,
+ optional (File or USVString or FormData)? state);
+
+ readonly attribute HTMLFormElement? form;
+
+ void setValidity(ValidityStateFlags flags,
+ optional DOMString message,
+ optional HTMLElement anchor);
+ readonly attribute boolean willValidate;
+ readonly attribute ValidityState validity;
+ readonly attribute DOMString validationMessage;
+ boolean checkValidity();
+ boolean reportValidity();
+
+ readonly attribute NodeList labels;
+};
+
+dictionary ValidityStateFlags {
+ boolean valueMissing = false;
+ boolean typeMismatch = false;
+ boolean patternMismatch = false;
+ boolean tooLong = false;
+ boolean tooShort = false;
+ boolean rangeUnderflow = false;
+ boolean rangeOverflow = false;
+ boolean stepMismatch = false;
+ boolean badInput = false;
+ boolean customError = false;
};
+
setFormValue
(value)setFormValue
(value,
+ state)form
setValidity
(flags,
+ message [, anchor ])reportValidity()
is
+ called.setValidity
({})willValidate
validity
ValidityState
object for internals's
+ target element.validationMessage
checkValidity()
invalid
event at the element in the latter case.
+ reportValidity()
invalid
event at the element, and
+ (if the event isn't canceled) reports the problem to the user.labels
NodeList
of all the label
elements that
+ internals's target element is associated with.
+ ElementInternals
has a target element,
which is a custom element. ElementInternals
provides various operations
@@ -67682,6 +68086,175 @@ interface ElementInternals {
targeting element, and return it.
+
+ File
, or a list of entries.File
, or a
+ list of entries.setFormValue()
method is used by
+ the custom element author to set the element's submission
+ value and state, thus communicating these to the user
+ agent.formStateRestoreCallback
", and an argument
+ list containing the state to be restored, and "restore"
.formStateRestoreCallback
", and an argument list containing the state value
+ determined by history of state value and some heuristics, and
+ "autocomplete"
."2019-03-15"
to the server. "3/15/2019" would be a state of the element, and "2019-03-15"
would be
+ a submission value.input
type. Its submission value would be the value of its value
content attribute, or the string "on"
. Its state would be one of "checked"
, "unchecked"
, "checked/indeterminate"
, or "unchecked/indeterminate"
.setFormValue(value,
+ state)
method of the ElementInternals
interface must
+ run the following steps:
+
+
+ ElementInternals
's target element.NotSupportedError
" DOMException
.FormData
object, or to a clone of the
+ entry list associated with value otherwise.FormData
object, set element's
+ state to clone of the
+ entry list associated with state.
+
+ valueMissing
, typeMismatch
,
+ patternMismatch
, tooLong
,
+ tooShort
, rangeUnderflow
,
+ rangeOverflow
, stepMismatch
, and
+ customError
. They are false initially.setValidity(flags,
+ message, anchor)
method of the ElementInternals
+ interface must run the following steps:
+
+
+ ElementInternals
's target element.NotSupportedError
" DOMException
.TypeError
.customError
validity flag is true, then set
+ element's custom validity error message to element's
+ validation message. Otherwise, set
+ element's custom validity error message to the empty string.NotFoundError
" DOMException
. Otherwise, set
+ element's validation anchor to
+ anchor.validationMessage
+ attribute of ElementInternals
interface, on getting, must return the
+ validation message of this
+ ElementInternals
's target element.
+
+
+ name
content attribute value. An implementation of
+ form-associated custom element is responsible to decide names of
+ entries. They can be the
+ name
content attribute value, they can be strings based on
+ the name
content attribute value, or they can be unrelated
+ to the name
content attribute.name
attribute
+ specified, or its name
attribute's value is the empty string,
+ then return.name
attribute value and the
+ submission value.Common idioms without dedicated elements
Bread crumb navigation
@@ -68069,6 +68642,8 @@ contradict people?
fieldset
element that is a disabled fieldsetbutton
, input
, select
, textarea
,
- optgroup
, option
, or fieldset
element that is not optgroup, option
, fieldset
element, or
+ form-associated custom element that is not actually disabled.
If element is a form-associated element, the If element is a form-associated element and not a
+ form-associated custom element, the
+ form
element pointer is not null, there is no template
- element on the stack of open elements, element is either not listed or doesn't have a form
element pointer is not null, there is no
+ template
element on the stack of open elements, element is
+ either not listed or doesn't have a form
attribute, and the intended parent is in the same
tree as the element pointed to by the form
element
pointer, then associate element
@@ -119455,7 +120032,8 @@ interface External {
output
;
select
;
textarea
;
- img
+ img
;
+ form-associated custom elements
—
@@ -119468,7 +120046,8 @@ interface External {
object
;
output
;
select
;
- textarea
+ textarea
;
+ form-associated custom elements
—
@@ -119479,7 +120058,8 @@ interface External {
input
;
object
;
select
;
- textarea
+ textarea
;
+ form-associated custom elements
—
@@ -119489,7 +120069,8 @@ interface External {
input
;
output
;
select
;
- textarea
+ textarea
;
+ form-associated custom elements
—
@@ -119514,7 +120095,8 @@ interface External {
output
;
progress
;
select
;
- textarea
+ textarea
;
+ form-associated custom elements
—
@@ -119855,6 +120437,12 @@ interface External {
textarea
Whether the form control is disabled
Boolean attribute
+
+ disabled
+ form-associated custom elements
+ Trigger " formDisabledCallback
" reaction, and
+ disable form submission for the element's data.
+ Boolean attribute
disabled
fieldset
@@ -119905,7 +120493,8 @@ interface External {
object
;
output
;
select
;
- textarea
+ textarea
;
+ form-associated custom elements
Associates the element with a form
element
ID*
@@ -120174,8 +120763,9 @@ interface External {
input
;
output
;
select
;
- textarea
- Name of the element to use for form submission and in the form.elements
API
+ textarea
;
+ form-associated custom elements
+ Name of the element to use for form submission and in the form.elements
API
Text*
name
@@ -120279,6 +120869,11 @@ interface External {
textarea
Whether to allow the value to be edited by the user
Boolean attribute
+
+ readonly
+ form-associated custom elements
+ Affects willValidate
+ Boolean attribute
referrerpolicy
a
;