Skip to content

Amphiluke/handy-scroll

Repository files navigation

handy-scroll

Handy dependency-free floating scrollbar web component.

Synopsis

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].

Installation and import

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";

Standard usage

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>

Custom viewport element

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>

API

HandyScroll.prototype.update()

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();

HandyScroll.prototype.owner

Reflects the value of the owner attribute, which in turn should reference the id attribute of the horizontally-scrollable container (owner).

HandyScroll.prototype.viewport

Reflects the value of the viewport attribute, which (if present) should reference the id attribute of the element serving as custom viewport.

Live demos

Check out some usage demos here.