A tiny parallax library that updates styles on scroll
- Plain old vanilla JS
- Just 1.8kb gzipped
Parallax works by listening to every scroll event. Now, that's not great, as it can really mess performance up.
Parallaxis allows only a few of the best performing element styles to be updated on scroll.
opacitytranslateXtranslateYscale
Still, overuse may kill performance. Especially on low-end devices.
Alternatively, take a look in /examples.
npm install parallaxis
<h1
class="js-parallaxis"
data-start="0"
data-end="200"
data-opacity-start="1"
data-opacity-end="0"
>
Hello world
</h1>import parallaxis from 'parallaxis'
parallaxis()The above example translates to:
- When
window.scrollYequals0then theopacityof theh1will be1. - When
window.scrollYequals200, or more, then theopacityof theh1will be0. - When
window.scrollYis somewhere between0and200then theopacityof theh1will be somewhere between0and1.
The parallaxis function can take an object, that
may include the following properties.
The class name that Parallaxis uses to locate elements.
Defaults to js-parallaxis.
parallaxis({ className: 'my-special-class' })Parallaxis uses element data attributes for configuration.
This is the window.scrollY position that will be the
element's update start point.
<h1
class="js-parallaxis"
data-start="0"
>
Hello world
</h1>This is the window.scrollY position that will be the
element's update end point.
<h1
class="js-parallaxis"
data-start="0"
data-end="200"
>
Hello world
</h1>Defining data-opacity-start and data-opacity-end will
result in opacity style updates.
<h1
class="js-parallaxis"
data-start="0"
data-end="200"
data-opacity-start="1"
data-opacity-end="0"
>
Hello world
</h1>Defining data-translatex-start and data-translatex-end
will result in transform: translateX() style updates.
<h1
class="js-parallaxis"
data-start="0"
data-end="200"
data-translatex-start="0"
data-translatex-end="200"
>
Hello world
</h1>Defining data-translatey-start and data-translatey-end
will result in transform: translateY() style updates.
<h1
class="js-parallaxis"
data-start="0"
data-end="200"
data-translatey-start="0"
data-translatey-end="200"
>
Hello world
</h1>Defining data-scale-start and data-scale-end
will result in transform: scale() style updates.
<h1
class="js-parallaxis"
data-start="0"
data-end="200"
data-scale-start="1"
data-scale-end="4"
>
Hello world
</h1>If data-relative is set to true, the data-start
and data-end attributes will be relative to the
element, rather than the window.
<h1
class="js-parallaxis"
data-relative="true"
data-start="-200"
data-end="0"
data-opacity-start="0"
data-opacity-end="1"
>
Hello world
</h1>Parallaxis is packaged with Babel, and
makes use of Array.from.
If you want Parallaxis to work on browsers that don't support
this method (e.g. IE11), then you will need to
polyfill Array.from
before calling parallaxis.