What's the proper value for a checked attribut

2018-12-31 22:10发布

问题:

We all know how to form a checkbox input in HTML:

<input name=\"checkbox_name\" id=\"checkbox_id\" type=\"checkbox\">

What I don\'t know -- what\'s the technically correct value for a checked checkbox? I\'ve seen these all work:

<input name=\"checkbox_name\" id=\"checkbox_id\" type=\"checkbox\" checked>
    <input name=\"checkbox_name\" id=\"checkbox_id\" type=\"checkbox\" checked=\"on\">
    <input name=\"checkbox_name\" id=\"checkbox_id\" type=\"checkbox\" checked=\"yes\">
    <input name=\"checkbox_name\" id=\"checkbox_id\" type=\"checkbox\" checked=\"checked\">
    <input name=\"checkbox_name\" id=\"checkbox_id\" type=\"checkbox\" checked=\"true\">

Is the answer that it doesn\'t matter? I see no evidence for the answer marked as correct here from the spec itself:

Checkboxes (and radio buttons) are on/off switches that may be toggled by the user. A switch is \"on\" when the control element\'s checked attribute is set. When a form is submitted, only \"on\" checkbox controls can become successful. Several checkboxes in a form may share the same control name. Thus, for example, checkboxes allow users to select several values for the same property. The INPUT element is used to create a checkbox control.

What would a spec writer say is the correct answer? Please provide evidence-based answers.

回答1:

Strictly speaking, you should put something that makes sense - according to the spec here, the most correct version is:

<input name=name id=id type=checkbox checked=checked>

For HTML, you can also use the empty attribute syntax, checked=\"\", or even simply checked (for stricter XHTML, this is not supported).

Effectively, however, most browsers will support just about any value between the quotes. All of the following will be checked:

<input name=name id=id type=checkbox checked>
<input name=name id=id type=checkbox checked=\"\">
<input name=name id=id type=checkbox checked=\"yes\">
<input name=name id=id type=checkbox checked=\"blue\">
<input name=name id=id type=checkbox checked=\"false\">

And only the following will be unchecked:

<input name=name id=id type=checkbox>

See also this similar question on disabled=\"disabled\".



回答2:

HTML5 spec:

http://www.w3.org/TR/html5/forms.html#attr-input-checked :

The disabled content attribute is a boolean attribute.

http://www.w3.org/TR/html5/infrastructure.html#boolean-attributes :

The presence of a boolean attribute on an element represents the true value, and the absence of the attribute represents the false value.

If the attribute is present, its value must either be the empty string or a value that is an ASCII case-insensitive match for the attribute\'s canonical name, with no leading or trailing whitespace.

Conclusion:

The following are valid, equivalent and true:

<input type=\"checkbox\" checked />
<input type=\"checkbox\" checked=\"\" />
<input type=\"checkbox\" checked=\"checked\" />
<input type=\"checkbox\" checked=\"ChEcKeD\" />

The following are invalid:

<input type=\"checkbox\" checked=\"0\" />
<input type=\"checkbox\" checked=\"1\" />
<input type=\"checkbox\" checked=\"false\" />
<input type=\"checkbox\" checked=\"true\" />

The absence of the attribute is the only valid syntax for false:

<input />

Recommendation

If you care about writing valid XHTML, use checked=\"checked\", since <input checked> is invalid XHTML (but valid HTML) and other alternatives are less readable. Else, just use <input checked> as it is shorter.



回答3:

<input ... checked />
<input ... checked=\"checked\" />

Those are equally valid. And in JavaScript:

input.checked = true;
input.setAttribute(\"checked\");
input.setAttribute(\"checked\",\"checked\");


回答4:

you want this i think: checked=\'checked\'



回答5:

  1. checked
  2. checked=\"\"
  3. checked=\"checked\"

    are equivalent;


according to spec checkbox \'----ⓘ checked = \"checked\" or \"\" (empty string) or empty Specifies that the element represents a selected control.---\'



回答6:

It\'s pretty crazy town that the only way to make checked false is to omit any values. With Angular 1.x, you can do this:

  <input type=\"radio\" ng-checked=\"false\">

which is a lot more sane, if you need to make it unchecked.



回答7:

Well, to use it i dont think matters (similar to disabled and readonly), personally i use checked=\"checked\" but if you are trying to manipulate them with JavaScript, you use true/false