Skip to content

A module for testing if a DOM element is visible in the viewport. Trigger callbacks are provided, as well as a configuration for surface trigger area.

Notifications You must be signed in to change notification settings

benobee/scrollmap

Repository files navigation


SCROLLMAP

Description

A module for testing if a DOM element is visible in the viewport, then triggers callbacks on execution.


Using ES6:

import Scrollmap from 'scrollmap';

Using a CDN via jsDelivr:

<script src="https://cdn.jsdelivr.net/npm/[email protected]/cdn/scrollmap.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/[email protected]/cdn/scrollmap.js"></script>

Method - trigger(options, callback)

Description: A method for adding triggers when element is visible in the viewport.

Properties for options config object:

target (string or element): Using querySelectorAll a target string selector is needed, or you can specify an actual element.

surfaceVisible (number): the percentage area, which is represented as a number from 0 - 1 is the area of the element which is visible in the viewport.

runOnScroll (boolean) : by default the callback is run only one time whent the element is visible. By changing to true, the callback will be run as long as the scroll event is happening.

alwaysRunOnTrigger (boolean): by default the triggered element callback will only be executed one time. Setting to true will re-trigger the callback everytime the element has been in and out of the viewport.

callback (object): This is the function which will be exectued when the element is detected in the viewport. To reference the node, pass it into the callback as an argument.

EXAMPLE

Scrollmap.trigger({
	target: '.collection-list .items',
	surfaceVisible: 0.5,
	runOnScroll: true,
	alwaysRunOnTrigger: true
}, (element) => {
	$(element).addClass("visible");
});

Method - sequence(options, callback)

Description: A method for staggering an array of triggers.

Properties for options config object:

interval: (number) : changes the interval speed of the sequence

order: (string) : changes the order of the sequence. Order options are "random", and "reverse".

callback (item, index): can get the item and index of the array as arguments

EXAMPLE

Scrollmap.trigger({
	target: ".boxes",
	surfaceVisible: 0.2
}, (element) => {
	const array = element.querySelectorAll(".box");

	Scrollmap.sequence(array, {
		interval: 5,
		order: "random"
	}, (item) => {

		//add any code to be triggered when
		//the element is in the viewport

		item.classList.add("color-change");

	});
});

Hooks

data-scrollmap-loaded (boolean): Once the element is initialized.

data-scrollmap-is-visible (boolean): If element is visible is viewport, the value will be set to true. When the elemnt is out of the viewport the value will be false.

data-scrollmap-triggered-in (boolean): After element detection in viewport, a boolean will be set to true. False is set as default.

data-scrollmap-triggered-out (boolean): After element detection is in and out of the viewport, a boolean will be set to true. False is set as default.

About

A module for testing if a DOM element is visible in the viewport. Trigger callbacks are provided, as well as a configuration for surface trigger area.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published