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.
opacity
translateX
translateY
scale
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.scrollY
equals0
then theopacity
of theh1
will be1
. - When
window.scrollY
equals200
, or more, then theopacity
of theh1
will be0
. - When
window.scrollY
is somewhere between0
and200
then theopacity
of theh1
will be somewhere between0
and1
.
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
.