-
Notifications
You must be signed in to change notification settings - Fork 197
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
[CHECKBOX] "unchecked" behavoir #313
Comments
I also use this "hack" to send an "unchecked" checkbox in a form: <input type='hidden' value='' name='accepted'>
<input type='checkbox' value='1' name='accepted'> This hack has a rating of 516 at stackoverflow And it is mentioned at MDN: I think if we have the possibilities to redesign the checkbox, we should improve it to this behavior. <checkbox value="1" name=accepted checked> <!-- checkbox.value === '1' -->
<checkbox value="1" name=accepted> <!-- checkbox.value === '' --> Conceivable would also be a future expansion with an attribute like "falsy". <checkbox value="on" falsy="off" name=accepted> |
@nuxodin thank you so much for filing this. This is the exact same issue that we just discussed in #311 - @domenic actually hits on the confusion of the current checkbox in this comment. Likewise this issue you raised was brought up to the TAG here. Ultimately the group seems to be in agreement that there need to be better cohesion in how the initial states relate to that of the IDL values themselves. As far as your proposals are concerned they need to follow the proposal for |
There hasn't been any discussion on this issue for a while, so we're marking it as stale. If you choose to kick off the discussion again, we'll remove the 'stale' label. |
My final solution would be: <checkbox on=yes off=no name=accepted> checkbox.value // no
checkbox.checked = true;
checkbox.value // yes Advantages:
|
There hasn't been any discussion on this issue for a while, so we're marking it as stale. If you choose to kick off the discussion again, we'll remove the 'stale' label. |
This suggestion was discussed and it was concluded that traditional check boxes should also be given an off value (as I understand it) This will probably look something like this: <input type=checkbox value=yes name=accepted **offvalue=no**>. Unfortunately this will result in So we still have to do something like this: let value = el.value; // other input
if (el.type==='checkbox') { // checkboxes
// value = el.checked ? el.value : ''; // old
value = el.checked ? el.value : el.offValue;
} I would rather there were new checkboxes that had a better API. |
I don't think that's necessarily true @nuxodin. With an opt-in attribute we could make |
Do you mean something like that? Current behavior <input type=checkbox value="true" checked>
// .value == "true"
<input type=checkbox value="true">
// .value == "true" // i think .value should be "" (empty string) Future <input type=checkbox value="true" offvalue="false" checked>
// .value == "true"
<input type=checkbox value="true" offvalue="false">
// .value == "false" |
Yes, something like that. What would help motivate such a feature would be more evidence that this is a problem web developers frequently run into. Stack Overflow questions might help with that as well as JS libraries that work around the issue. |
There hasn't been any discussion on this issue for a while, so we're marking it as stale. If you choose to kick off the discussion again, we'll remove the 'stale' label. |
I would really like it that when a checkbox is unchecked its value is an empty string.
I don't know about others, but i have to do this hack all the time:
The text was updated successfully, but these errors were encountered: