3.3.12 • Published 4 years ago

@badsmuggler/locomotive-scroll v3.3.12

Weekly downloads
-
License
MIT
Repository
github
Last release
4 years ago

Installation

npm install locomotive-scroll

Usage

Basic

With simple detection.

HTML

<h1 data-scroll>Hey</h1>
<p data-scroll>👋</p>

CSS

Add the base styles to your CSS file.

locomotive-scroll.css

JS

With a bundler
import LocomotiveScroll from 'locomotive-scroll';

const scroll = new LocomotiveScroll();
Or without
<script src="locomotive-scroll.min.js"></script>
<script>
    (function () {
        var scroll = new LocomotiveScroll();
    })();
</script>

Get the JS file.

Smooth

With smooth scrolling and parallax.

<div data-scroll-container>
    <div data-scroll-section>
        <h1 data-scroll>Hey</h1>
        <p data-scroll>👋</p>
    </div>
    <div data-scroll-section>
        <h2 data-scroll data-scroll-speed="1">What's up?</h2>
        <p data-scroll data-scroll-speed="2">😬</p>
    </div>
</div>
import LocomotiveScroll from 'locomotive-scroll';

const scroll = new LocomotiveScroll({
    el: document.querySelector('[data-scroll-container]'),
    smooth: true
});

Note: scroll-sections are optional but recommended to improve performance, particularly in long pages.

Advanced

Make it do what you want.

With methods

<section id="js-target">Come here please.</section>
import LocomotiveScroll from 'locomotive-scroll';

const scroll = new LocomotiveScroll();
const target = document.querySelector('#js-target');

scroll.scrollTo(target);

With events

<!-- Using modularJS -->
<div data-scroll data-scroll-call="function, module">Trigger</div>
<!-- Using jQuery events -->
<div data-scroll data-scroll-call="EVENT_NAME">Trigger</div>
<!-- Or do it your own way 😎 -->
<div data-scroll data-scroll-call="{y,o,l,o}">Trigger</div>
import LocomotiveScroll from 'locomotive-scroll';

const scroll = new LocomotiveScroll();

scroll.on('call', func => {
    // Using modularJS
    this.call(...func);
    // Using jQuery events
    $(document).trigger(func);
    // Or do it your own way 😎
});

Instance options

OptionTypeDefaultDescription
elobjectdocumentScroll container element.
namestring'scroll'Data attribute prefix (data-scroll-xxxx).
offsetarray(2)[0,0]Global in-view trigger offset : [bottom,top]Use a string with % to use a percentage of the viewport height.Use a numeric value for absolute pixels unit.E.g. ["30%",0], [100,0], ["30%", 100]
repeatbooleanfalseRepeat in-view detection.
smoothbooleanfalseSmooth scrolling.
smoothMobilebooleanfalseSmooth scrolling on iOS and Android devices.
directionstringverticalScroll direction.
inertianumber1Lerp intensity.
getDirectionbooleanfalseAdd direction to scroll event.
getSpeedbooleanfalseAdd speed to scroll event.
classstringis-inviewElement in-view class.
initClassstringhas-scroll-initInitialize class.
scrollingClassstringhas-scroll-scrollingIs scrolling class.
draggingClassstringhas-scroll-draggingIs dragging class.
smoothClassstringhas-scroll-smoothHas smooth scrolling class.
scrollbarClassstringc-scrollbarScrollbar element class.
firefoxMultipliernumber50Boost scrolling speed of Firefox on Windows.
touchMultipliernumber2Mutiply touch action to scroll faster than finger movement.

Element attributes

AttributeValuesDescription
data-scrollDetect if in-view.
data-scroll-containerDefines the scroll container. Required for basic styling.
data-scroll-sectionDefines a scrollable section. Splitting your page into sections may improve performance.
data-scroll-classstringElement in-view class.
data-scroll-offsetstringElement in-view trigger offset : bottom,topFirst value is bottom offset, second (optional) is top offset. Percent is relative to viewport height, otherwise it's absolute pixels.E.g. "10", "100,50%", "25%, 15%"
data-scroll-repeattrue, falseElement in-view detection repeat.
data-scroll-callstringElement in-view trigger call event.
data-scroll-speednumberElement parallax speed. A negative value will reverse the direction.
data-scroll-targetstringTarget element's in-view position.
data-scroll-positiontop, bottomWindow position of in-view trigger.
data-scroll-directionvertical, horizontalElement's parallax direction.
data-scroll-delaynumberElement's parallax lerp delay.
data-scroll-stickySticky element. Starts and stops at data-scroll-target position.

Instance methods

MethodDescriptionArguments
init()Reinitializes the scroll.
on(eventName, function)Listen instance events ⬇.
update()Updates all element positions.
destroy()Destroys the scroll events.
start()Restarts the scroll events.
stop()Stops the scroll events.
scrollTo(target, offset)Scroll to an element.target: Defines where you want to scroll. Available values types are :node : a dom elementstring : you can type your own selector, or use values "top" and "bottom" to reach scroll boundariesint : An absolute scroll coordinate in pixelsoffset (optionnal) : A number that defines an offset from your target. E.g. -100 if you want to scroll 100 pixels above your target

Instance events

EventArgumentsDescription
scrollobjReturns scroll instance (position, limit, speed, direction).
callfuncTrigger if in-view. Returns your string or array if contains ,.

Dependencies

NameDescription
Virtual ScrollCustom scroll event with inertia/momentum.
modularScrollElements in viewport detection. Forked from it, not a dependency.

Browser support

Works on most modern browsers. Chrome, Firefox, Safari, Edge...

To get IE 11 support, you need polyfills. You can use your own or include these before our script.

<script nomodule src="https://cdnjs.cloudflare.com/ajax/libs/babel-polyfill/7.6.0/polyfill.min.js" crossorigin="anonymous"></script>
<script nomodule src="https://polyfill.io/v3/polyfill.min.js?features=Object.assign%2CElement.prototype.append%2CNodeList.prototype.forEach%2CCustomEvent%2Csmoothscroll" crossorigin="anonymous"></script>

Related