I have a problem that I'm not even sure what to search for in order to fix. When I press the spacebar my entire page moves up (scrolls down): I don't want this to happen. My body
tag is styled to overflow:hidden
, if that has anything to do with it, so the page won't have any scrollbars. I'm usually pretty good at executing the preliminary troubleshooting techniques but in this case I don't even know where to start. How can I stop this behaviour?
Additional information: I am using jQuery 1.4.2
This default scrolling behavior comes from the keydown
event. In order to prevent it, you must handle the keydown
event and prevent the default behavior, either by returning false
from the event handler or calling event.preventDefault()
.
As a rule of thumb, think carefully before you prevent default behavior like spacebar scrolling. I use it all the time and I get extremely annoyed when it doesn't work in a page.
But if you want to eat the key...
window.onkeydown = function(e) {
return e.keyCode !== 32;
};
According to the MDN web docs for KeyboardEvent#keyCode
, keyCode
is a deprecated property. Although it still works in most browsers, you are encouraged to use KeyboardEvent#key
going forward, which is a more standardized string representation of a key. The key
value for spacebar is literally the input value: " "
(single space string). So if you wanted to be very careful to support all browsers, you could write:
window.onkeydown = function(e) {
return ev.keyCode !== 32 && ev.key !== " ";
}
It's not enough to just hide the overflow; you actually have to make it not overflow. Even if you could disable the behavior (eating the keystroke, putting focus inside some other container), the user might still be able to scroll via the keyboard, by drag-selecting text on the page, holding down the middle mouse button, etc... It's really up to their browser, and so long as the content is still technically visible, they'll probably have some way to scroll it into view.
Time to re-think your layout.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With