It's a copy of my answer that I posted here: https://stackoverflow.com/a/63221105/4336168
I use these two functions for this:
function enableBodyScroll() {
if (document.readyState === 'complete') {
document.body.style.position = '';
document.body.style.overflowY = '';
if (document.body.style.marginTop) {
const scrollTop = -parseInt(document.body.style.marginTop, 10);
document.body.style.marginTop = '';
window.scrollTo(window.pageXOffset, scrollTop);
}
} else {
window.addEventListener('load', enableBodyScroll);
}
}
function disableBodyScroll({ savePosition = false } = {}) {
if (document.readyState === 'complete') {
if (document.body.scrollHeight > window.innerHeight) {
if (savePosition) document.body.style.marginTop = `-${window.pageYOffset}px`;
document.body.style.position = 'fixed';
document.body.style.overflowY = 'scroll';
}
} else {
window.addEventListener('load', () => disableBodyScroll({ savePosition }));
}
}
How it works:
When you want to disable the scroll with saving the current position, you run disableBodyScroll({ savePosition: true })
.
The function check whether the page loaded or not (because user may trigger dialog opening during the loading).
If the page is loaded, it saves current scroll position by setting margin-top
on body
, then it sets position: fixed; overflow-y: scroll
on it to remove scrollbar.
If the page isn't loaded, it adds event listener to run (3.) when the page loads.
For enabling scroll everything is the same, but the function remove styles instead of setting them.
Source of the code, so they can be used like this:
npm install --save @funboxteam/diamonds
import { enableBodyScroll, disableBodyScroll } from '@funboxteam/diamonds';