dom-peekaboo

Functions for tracking a DOM node's intersection with the viewport.

Usage no npm install needed!

<script type="module">
  import domPeekaboo from 'https://cdn.skypack.dev/dom-peekaboo';
</script>

README

dom-peekaboo

CI status

Functions for tracking a DOM node's intersection with the viewport.

Installation

npm install dom-peekaboo

Usage

import { peekaboo } from 'dom-peekaboo';

function onChange(isIntersecting) {
  console.log(
    `Element is ${isIntersecting ? 'visible' : 'not visible'} in the viewport`,
  );
}

peekaboo(document.getElementById('test'), onChange);

API

Parameters

All functions accept the same set of parameters with the following type:

(
  element: HTMLElement,
  onChange: (isIntersecting: boolean) => void,
  options?: Options,
) => () => void;

The following options are available:

  • offsetBottom?: number: Number of pixels to add to the bottom of the area checked against when computing element intersection. (default: 0)

  • offsetLeft?: number: Number of pixels to add to the left of the area checked against when computing element intersection. (default: 0)

  • offsetRight?: number: Number of pixels to add to the right of the area checked against when computing element intersection. (default: 0)

  • offsetTop?: number: Number of pixels to add to the top of the area checked against when computing element intersection. (default: 0)

  • throttle?: number: Number of ms to throttle scroll events (only applies in environments that don't support IntersectionObserver or when using useScrollIntersection/useScrollIntersectionChangeCallback). (default: 100)

Exports

  • io: Uses an IntersectionObserver to trigger onChange when element enters or exits the viewport.

  • scroll: Uses a scroll event listener, getBoundingClientRect, and ResizeObserver to trigger onChange when element enters or exits the viewport.

  • peekaboo: Uses io to trigger onChange in browsers that support IntersectionObserver and falls back to using scroll in browsers that don't.

Caveats