-
Notifications
You must be signed in to change notification settings - Fork 2.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update content model for customizable select #10586
base: main
Are you sure you want to change the base?
Changes from 12 commits
088b919
16fadde
3c57a19
e27ea83
44225a8
c7deb50
e4d071c
fb7ca7a
841e6ff
c6c208c
0891d73
787e86f
bfa1c18
a4954ad
15f67ea
93ebe9e
b6cebc4
ced6411
57dced1
eb42bf6
22b839c
f40e975
19c1c04
aa9436e
eab0bc6
7f9cc16
bed729f
5059234
b44ec20
e85aaab
f9654e2
f3cfbac
e9c98a1
f0aa6ff
1117978
77d2782
e4e7197
b3fbb47
08ce60d
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -12785,6 +12785,68 @@ https://software.hixie.ch/utilities/js/live-dom-viewer/?%3C%21DOCTYPE%20HTML%3E% | |
</ul> | ||
|
||
|
||
<h6>Select element inner content elements</h6> | ||
|
||
<p><dfn>Select element inner content elements</dfn> are <code>option</code> elements and other | ||
elements which are used to group and decorate them with a <code>select</code> element.</p> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This reads weird. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I re-wrote it like this: ... are the elements which are allowed as descendants of select elements. |
||
|
||
<p>The following are <span>select element inner content elements</span>:</p> | ||
|
||
<ul class="brief category-list"> | ||
<li><code>option</code> elements.</li> | ||
|
||
<li><code>optgroup</code> elements.</li> | ||
|
||
<li><code>hr</code> elements.</li> | ||
|
||
<li><span>script-supporting elements</span>.</li> | ||
|
||
<li><code>noscript</code> elements.</li> | ||
|
||
<li><code>div</code> elements.</li> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
</ul> | ||
|
||
<h6>Optgroup element inner content elements</h6> | ||
|
||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<p><dfn>Optgroup element inner content elements</dfn> are the elements which are allowed as | ||
descendants of <code>optgroup</code> elements.</p> | ||
|
||
<p>The following are <span>optgroup element inner content elements</span>:</p> | ||
|
||
<ul class="brief category-list"> | ||
<li><code>option</code> elements.</li> | ||
|
||
<li><span>script-supporting elements</span>.</li> | ||
|
||
<li><code>noscript</code> elements.</li> | ||
|
||
<li><code>div</code> elements.</li> | ||
</ul> | ||
|
||
<h6>Option element inner content elements</h6> | ||
|
||
<p><dfn>Option element inner content elements</dfn> are the elements which are allowed as | ||
descendants of <code>option</code> elements.</p> | ||
|
||
<p>The following are <span>option element inner content elements</span>:</p> | ||
|
||
<ul class="brief category-list"> | ||
<li><span>Text content</span>.</li> | ||
|
||
<li><span>Palpable content</span> except for <span>interactive content</span>.</li> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
<li><span>script-supporting elements</span>.</li> | ||
|
||
<li><code>noscript</code> elements.</li> | ||
|
||
<li><code>span</code> elements.</li> | ||
|
||
<li><code>img</code> elements.</li> | ||
|
||
<li><span>SVG <code>svg</code></span> elements.</li> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
</ul> | ||
|
||
|
||
|
||
<h5>Transparent content models</h5> | ||
|
||
|
@@ -19774,6 +19836,8 @@ and is further discussed below.</div></code></pre> | |
<dl class="element"> | ||
<dt><span data-x="concept-element-categories">Categories</span>:</dt> | ||
<dd><span>Flow content</span>.</dd> | ||
<dd><span>Select element inner content elements</span>.</dd> | ||
<dd><span>Optgroup element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dt><span data-x="concept-element-contexts">Contexts in which this element can be used</span>:</dt> | ||
<dd>Where <span>flow content</span> is expected.</dd> | ||
<dd>As a child of a <code>select</code> element.</dd> | ||
|
@@ -21508,12 +21572,17 @@ included with Exhibit B. | |
<dt><span data-x="concept-element-categories">Categories</span>:</dt> | ||
<dd><span>Flow content</span>.</dd> | ||
<dd><span>Palpable content</span>.</dd> | ||
<dd><span>Select element inner content elements</span>.</dd> | ||
<dd><span>Option element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dd><span>Optgroup element inner content elements</span>.</dd> | ||
<dt><span data-x="concept-element-contexts">Contexts in which this element can be used</span>:</dt> | ||
<dd>Where <span>flow content</span> is expected.</dd> | ||
<dd>As a child of a <code>dl</code> element.</dd> | ||
<dt><span data-x="concept-element-content-model">Content model</span>:</dt> | ||
<dd>If the element is a child of a <code>dl</code> element: one or more <code>dt</code> elements followed by one or more <code>dd</code> elements, optionally intermixed with <span>script-supporting elements</span>.</dd> | ||
<dd>If the element is not a child of a <code>dl</code> element: <span>flow content</span>.</dd> | ||
<dd>Otherwise, if the element is a descendant of an <code>option</code> element: Zero or more <span>option element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dd>Otherwise, if the element is a descendant of an <code>optgroup</code> element: Zero or more <span>optgroup element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dd>Otherwise: <span>flow content</span>.</dd> | ||
<dt><span data-x="concept-element-attributes">Content attributes</span>:</dt> | ||
<dd><span>Global attributes</span></dd> | ||
<dt><span | ||
|
@@ -24325,10 +24394,15 @@ wormhole connection.</mark></p></code></pre> | |
<dd><span>Flow content</span>.</dd> | ||
<dd><span>Phrasing content</span>.</dd> | ||
<dd><span>Palpable content</span>.</dd> | ||
<dd><span>Select element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dd><span>Option element inner content elements</span>.</dd> | ||
<dd><span>Optgroup element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dt><span data-x="concept-element-contexts">Contexts in which this element can be used</span>:</dt> | ||
<dd>Where <span>phrasing content</span> is expected.</dd> | ||
<dt><span data-x="concept-element-content-model">Content model</span>:</dt> | ||
<dd><span>Phrasing content</span>.</dd> | ||
<dd>If the element is a descendant of an <code>option</code> element: Zero or more <span>option element inner content elements</span>.</dd> | ||
<dd>Otherwise, if the element is a descendant of an <code>optgroup</code> element: Zero or more <span>optgroup element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dd>Otherwise: <span>Phrasing content</span>.</dd> | ||
<dt><span data-x="concept-element-attributes">Content attributes</span>:</dt> | ||
<dd><span>Global attributes</span></dd> | ||
<dt><span | ||
|
@@ -29053,6 +29127,9 @@ interface <dfn interface>HTMLSourceElement</dfn> : <span>HTMLElement</span> { | |
<dd><span>Form-associated element</span>.</dd> | ||
<dd>If the element has a <code data-x="attr-hyperlink-usemap">usemap</code> attribute: <span>Interactive content</span>.</dd> | ||
<dd><span>Palpable content</span>.</dd> | ||
<dd><span>Select element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dd><span>Option element inner content elements</span>.</dd> | ||
<dd><span>Optgroup element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dt><span data-x="concept-element-contexts">Contexts in which this element can be used</span>:</dt> | ||
<dd>Where <span>embedded content</span> is expected.</dd> | ||
<dd>As a child of a <code>picture</code> element, after all <code>source</code> elements.</dd> | ||
|
@@ -53203,7 +53280,7 @@ interface <dfn interface>HTMLButtonElement</dfn> : <span>HTMLElement</span> { | |
<dt><span data-x="concept-element-contexts">Contexts in which this element can be used</span>:</dt> | ||
<dd>Where <span>phrasing content</span> is expected.</dd> | ||
<dt><span data-x="concept-element-content-model">Content model</span>:</dt> | ||
<dd>Zero or more <code>option</code>, <code>optgroup</code>, <code>hr</code>, and <span data-x="script-supporting elements">script-supporting</span> elements.</dd> | ||
<dd>Zero or one <code>button</code> element followed by zero or more <span>select element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Description of "As first child of select element" should be added to "Contexts in which this element can be used:" of section of "4.10.6 The button element". In this case, this button element is neither of "Submit Button" state, "Reset Button" state or "Button" state. In addition, Shouldn't The following sentent be added to section of "4.10.6 The button element"?
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Done
Those states are based on the type attribute. Since we didn't add any states when adding popovertarget, I don't think we should add a state here. I suppose that we could say that the type attribute should not be set when the button is the first child of a select or when it has the popovertarget attribute though? Perhaps as a follow-up? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. In "type" attribute of button element, the attribute's missing value default and invalid value default are both the Submit Button state. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. defining a fourth button type sounds like it could be potential scope creep, but @mtrootyy does make a good point that it is probably worth noting that this button is not a submit button, and that it also probably shouldn't even allow many of the attributes that would be valid for a button in other contexts. |
||
<dt><span data-x="concept-element-attributes">Content attributes</span>:</dt> | ||
<dd><span>Global attributes</span></dd> | ||
<dd><code data-x="attr-fe-autocomplete">autocomplete</code></dd> | ||
|
@@ -53930,11 +54007,11 @@ interface <dfn interface>HTMLDataListElement</dfn> : <span>HTMLElement</span> { | |
|
||
<dl class="element"> | ||
<dt><span data-x="concept-element-categories">Categories</span>:</dt> | ||
<dd>None.</dd> | ||
<dd><span>Select element inner content elements</span>.</dd> | ||
<dt><span data-x="concept-element-contexts">Contexts in which this element can be used</span>:</dt> | ||
<dd>As a child of a <code>select</code> element.</dd> | ||
<dd>As a descendant of a <code>select</code> element.</dd> | ||
<dt><span data-x="concept-element-content-model">Content model</span>:</dt> | ||
<dd>Zero or more <code>option</code> and <span data-x="script-supporting elements">script-supporting</span> elements.</dd> | ||
<dd>Zero or one <code>legend</code> element followed by zero or more <span>optgroup element inner content elements</span>.</dd> | ||
josepharhar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
<dt><span data-x="concept-element-attributes">Content attributes</span>:</dt> | ||
<dd><span>Global attributes</span></dd> | ||
<dd><code data-x="attr-optgroup-disabled">disabled</code></dd> | ||
|
@@ -54027,19 +54104,16 @@ interface <dfn interface>HTMLOptGroupElement</dfn> : <span>HTMLElement</span> { | |
|
||
<dl class="element"> | ||
<dt><span data-x="concept-element-categories">Categories</span>:</dt> | ||
<dd>None.</dd> | ||
<dd><span>Select element inner content elements</span>.</dd> | ||
<dd><span>Optgroup element inner content elements</span>.</dd> | ||
<dt><span data-x="concept-element-contexts">Contexts in which this element can be used</span>:</dt> | ||
<dd>As a child of a <code>select</code> element.</dd> | ||
<dd>As a descendant of a <code>select</code> element.</dd> | ||
<dd>As a child of a <code>datalist</code> element.</dd> | ||
<dd>As a child of an <code>optgroup</code> element.</dd> | ||
<dd>As a descendant of an <code>optgroup</code> element.</dd> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. "Content model:" should become the following.
Because the submitted value must be simply text, and "option element inner content elements" is only used to decorate label text. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm not sure I want to force authors to set a value attribute for simple cases like this: <select>
<option><svg>...</svg><span>Purple</span></option>
<option><svg>...</svg><span>Green</span></option>
</select> In this case, we can just use the text contents of the option, which would be "purple" and "green", just like we already do without the value attribute. I suppose it would make sense to enforce that there is either a value attribute or some text node descendant of the option. Do you agree? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
In the above case, if there is no value attribute, the submitted value will be "22","3".
In the above case, if there is no value attribute, the submitted value will be "male,female" regardless of which option is selected. Because there are many cases like this, shouldn't it be enforce to specify the value attribute? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If the author is actually using the value property of the select for anything, then I think they will notice odd cases like this and use the value attribute, just like they are already doing today since it is currently optional. I could imagine cases today where the author puts non-ascii unicode characters into the option's text, and then has difficulties parsing it later when its submitted to their server in a form. I don't want to start requiring an explicit value attribute in cases like this either. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If value attribute shouldn't be required in this case, shouldn't some kind of note regarding above points be described? |
||
<dt><span data-x="concept-element-content-model">Content model</span>:</dt> | ||
<dd>If the element has a <code data-x="attr-option-label">label</code> attribute and a <code data-x="attr-option-value">value</code> attribute: <span data-x="concept-content-nothing">Nothing</span>.</dd> | ||
<dd>If the element has a <code data-x="attr-option-label">label</code> attribute but no <code data-x="attr-option-value">value</code> attribute: <span data-x="text content">Text</span>.</dd> | ||
<dd>If the element has no <code data-x="attr-option-label">label</code> attribute and is not a | ||
child of a <code>datalist</code> element: <span data-x="text content">Text</span> that is not | ||
<span>inter-element whitespace</span>.</dd> | ||
<dd>If the element has no <code data-x="attr-option-label">label</code> attribute and is a child | ||
of a <code>datalist</code> element: <span data-x="text content">Text</span>.</dd> | ||
<dd>If the element has no <code data-x="attr-option-label">label</code> attribute: Zero or more <span>option element inner content elements</span>.</dd> | ||
<dt><span data-x="concept-element-attributes">Content attributes</span>:</dt> | ||
<dd><span>Global attributes</span></dd> | ||
<dd><code data-x="attr-option-disabled">disabled</code></dd> | ||
|
@@ -63298,6 +63372,9 @@ not-slash = %x0000-002E / %x0030-10FFFF | |
<dd><span>Metadata content</span>.</dd> | ||
<dd><span>Flow content</span>.</dd> | ||
<dd><span>Phrasing content</span>.</dd> | ||
<dd><span>Select element inner content elements</span>.</dd> | ||
<dd><span>Option element inner content elements</span>.</dd> | ||
<dd><span>Optgroup element inner content elements</span>.</dd> | ||
<dt><span data-x="concept-element-contexts">Contexts in which this element can be used</span>:</dt> | ||
<dd>In a <code>head</code> element of an <span data-x="HTML documents">HTML document</span>, if there are no ancestor <code>noscript</code> elements.</dd> | ||
<dd>Where <span>phrasing content</span> is expected in <span>HTML documents</span>, if there are no ancestor <code>noscript</code> elements.</dd> | ||
|
@@ -139670,6 +139747,8 @@ interface <dfn interface>External</dfn> { | |
<td><code>HTMLElement</code></td> | ||
</tr> | ||
|
||
<!-- TODO update this and other part of this table after the duplicate parts earlier in the spec | ||
are finalized. --> | ||
<tr> | ||
<th><code>select</code></th> | ||
<td>List box control</td> | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it's rather confusing to have both
select
element and "Select element".There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure if I should reference
<code>select</code>
in the<dfn>
for this concept, and I didn't make all of the references to it do that either.Should I do that instead? Or are there other places where I'm using
<code>select</code>
that should just be "select"?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can use a
code
element in a term without it itself being a reference (withdata-x=""
). Example: https://html.spec.whatwg.org/#the-head-element-2