SolidJS utility that prevents scrolling outside of a given DOM element. Works by preventing events that else would lead to scrolling.
npm install solid-prevent-scrollSolidJS utility that prevents scrolling outside of a given DOM element. Works by preventing events that else would lead to scrolling.
- Supports nested scroll containers
- Works both vertically and horizontally
- Removes the body scrollbar without layout shift
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.
``tsx`
import createPreventScroll from 'solid-prevent-scroll'
`tsx
const DialogContent: Component<{
open: boolean
}> = (props) => {
const [ref, setRef] = createSignal(null)
createPreventScroll({
element: ref,
enabled: () => props.open, // default = true
hideScrollbar: true, // default
preventScrollbarShift: true, // default
preventScrollbarShiftMode: 'padding', // default, padding or margin
restoreScrollPosition: true, // default
allowPinchZoom: false, // default
})
return (
Dialog
)
}
`
Use the --scrollbar-width CSS variable to add padding to fixed elements to prevent the content from shifting when the scrollbar is removed:
`tsx``
style={{
'padding-right': 'var(--scrollbar-width, 0)',
}}
>
Header