-
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
input[type=checkbox] is mutable even when disabled on every browser #5000
Comments
Is this #4328 perhaps? |
#4328 seems to be about elements disabled after legacy-pre-activation behavior but this is more about the elements that already have been disabled. |
Relevant bugs: Gecko: https://bugzilla.mozilla.org/show_bug.cgi?id=1540995 |
For reference, it appears that all modern browsers will toggle the disabled checkbox, and issue an 'input' event, when a synthetic 'click' event is sent. My guess would be that the spec should be clarified to match existing browser behavior in this case. |
I explored to modify the spec but got a blocker. 6.4 Activation behavior of elements says:
... but both Firefox and Chrome trigger it without a click event. Ah never mind, DOM does not care about |
This section of the spec says this:
However, the WPT added for this shows that Also, the code in blink which implements this sentence in the spec about click events will completely cancel the click event and prevent it from being dispatched on any nodes if there is any node in the event path which is a disabled form control. However, it seems like this is not what gecko or webkit are doing - they still emit click events on child and/or parent nodes of the disabled form control for various types of clicks. I assume that our new test also permits click events on child and/or parent nodes of disabled form controls: web-platform-tests/wpt#32381 If we update this sentence, this should probably be spelled out too. |
The spec limits the behavior to events from user interaction task source, so I believe it does not block dispatchEvent.
Per https://wpt.fyi/results/html/semantics/forms/event-propagate-disabled.html?diff&filter=ADC&run_id=5757896716451840&run_id=5695315419070464 Gecko does not do that, do you have a test case that shows the behavior? It completely blocks pointerdown/up/click per my observation.
Yup, I'll prepare a spec PR soon when I get confident enough that we have enough consensus around the tests. |
Awesome!
<div id=testparent>
<button disabled id=test>disabled button
<span id=testchild style="border:1px solid black">child span</span>
</button>
</div>
<div id=output></div>
<script>
function log(str) {
output.insertAdjacentHTML('beforeend', `<div>${str}</div>`);
}
test.addEventListener('click', () => log('click handler'));
testparent.addEventListener('click', () => log('parent click handler'));
testchild.addEventListener('click', () => log('child click handler'));
</script> Physically clicking "child span" fires the click event on no elements in blink, fires only on the child element in gecko, and fires on the child and parent elements in webkit. After my fix to implement web-platform-tests/wpt#32381 in blink, then blink webkit and gecko will all have the same behavior for |
With
👍 |
Oof, I don't think the flag should be taking away events like that, I'll have to look into it. Is there a test case in web-platform-tests/wpt#32381 which covers this? What is the desired behavior? |
We want things to bubble, so in this case we need to follow what WebKit (and Blink by default!) does.
No, I'll have to add one... |
I think the test titled |
Hmm yes, I mean the one that "checks whether the child element gets the event" does not exist and probably worth having one. |
Test page: https://disabled-form-element.glitch.me/
The page dispatches a synthesized click event when you click the "Click" button to the checkbox and every browser (Firefox, Chrome, and Epiphany (WebKit; I have no Safari 😅)) mutates the disabled checkbox. This violates the spec:
But based on the actual behaviors, should this be allowed?
Edit: issue number 5000 🎉
The text was updated successfully, but these errors were encountered: