Handy dependency-free floating scrollbar web component.
handy-scroll is a dependency-free web component which can be used to solve the problem of scrolling lengthy containers horizontally when those containers don’t fit into the viewport. The component is just a scrollbar which is attached at the bottom of the container’s visible area. It doesn’t get out of sight when the page is scrolled, thereby making horizontal scrolling of the container much handier.
Note
Current version of the component targets modern browsers only. If you need to support older browser versions, please stick to the former implementation [email protected].
If you use a bundler in your project, install handy-scroll as a dependency:
npm install handy-scroll
Now you may import it wherever it’s needed:
import "handy-scroll";
If you don’t use bundlers, just import the component as a module in your HTML files:
<script type="module" src="https://esm.run/handy-scroll"></script>
or in your ES modules:
import "https://esm.run/handy-scroll";
Drop the custom element <handy-scroll>
where you need in your markup and link the component to the horizontally-scrollable target using the owner
attribute:
<div id="horizontally-scrollable">
<!-- Horizontally wide contents -->
</div>
<handy-scroll owner="horizontally-scrollable"></handy-scroll>
Standard use case above implies that handy-scroll will stick to the bottom of the browser window viewport. If instead you want to attach a floating scrollbar at the bottom of your custom scrollable “viewport” (e.g. a scrollable modal popup), then you need to link the component to your custom viewport element using the viewport
attribute:
<div id="custom-viewport">
<div id="horizontally-scrollable">
<!-- Horizontally wide contents -->
</div>
<handy-scroll owner="horizontally-scrollable" viewport="custom-viewport"></handy-scroll>
</div>
handy-scroll automatically tracks viewport changes in order to keep the component’s size, position and visibility in sync with the owner’s metrics. However there can be some cases when you’ll need to trigger the component update programmatically (e.g. after some changes in DOM). To do so, just call the method update()
on the specific <handy-scroll>
element:
document.getElementById("my-handy-scroll").update();
Reflects the value of the owner
attribute, which in turn should reference the id
attribute of the horizontally-scrollable container (owner).
Reflects the value of the viewport
attribute, which (if present) should reference the id
attribute of the element serving as custom viewport.
Check out some usage demos here.