Prevent Scroll
Utility that prevents scrolling outside of a given DOM element. Works by preventing events that else would lead to scrolling.
Features Section titled Features
- Supports nested scroll containers
- Works both vertically and horizontally
- Removes the body scrollbar without layout shift
Installation Section titled Installation
npm install solid-prevent-scroll
Usage Section titled Usage
By default, it also hides the scrollbar of the body element and adds padding to it to prevent the page from jumping. This behavior can be disabled and modified with the hideScrollbar
, preventScrollbarShift
, and preventScrollbarShiftMode
props.
It also adds the CSS variable --scrollbar-width
to the body element, indicating the width of the currently removed scrollbar. You can use this variable to add padding to fixed elements, like a topbar.
import createPreventScroll from 'solid-prevent-scroll'
const DialogContent: Component<{
open: boolean
}> = (props) => {
const [ref, setRef] = createSignal(null)
createPreventScroll({
element: ref,
enabled: () => props.open,
hideScrollbar: true, // default
})
return (
<Show when={props.open()}>
<div ref={setRef}>Dialog</div>
</Show>
)
}
Use the --scrollbar-width
CSS variable to add padding to fixed elements to prevent the content from shifting when the scrollbar is removed:
<header
class="fixed top-0 inset-x-0 z-50"
style={{
'padding-right': 'var(--scrollbar-width, 0)',
}}
>
Header
</header>
API reference Section titled API reference
Props
Property | Default | Type/Description |
---|---|---|
element | null | MaybeAccessor<null | HTMLElement> Prevent scroll outside of this element. If the element is null , scroll will be prevented on the whole page. |
enabled | true | MaybeAccessor<boolean> Whether scroll should be prevented. |
hideScrollbar | true | MaybeAccessor<boolean> Whether the scrollbar of the element should be hidden. |
preventScrollbarShift | true | MaybeAccessor<boolean> Whether padding should be added to the element to avoid layout shift. |
preventScrollbarShiftMode | 'padding' | MaybeAccessor<'padding' | 'margin'> Whether padding or margin should be used to avoid layout shift. |
restoreScrollPosition | true | MaybeAccessor<boolean> Whether to restore the scroll position with window.scrollTo to avoid possible layout shift after disabling the utility. |
allowPinchZoom | false | MaybeAccessor<boolean> Whether pinch zoom should be allowed. |
Developed and designed by Jasmin