New: This is now a React library, Vanilla JS is still availableRead more
simpleParallax.js

simpleParallax.js

Easy Parallax Effect for React & JavaScript

$npm i simple-parallax-js

simpleParallax.js is a lightweight and easy-to-use JS & React library that adds parallax animations to any image.
While other plugins can be complex, simpleParallax.js is notable for its simplicity and impressive visual effects. The parallax effect is applied directly to image tags, eliminating the need for background images. Any image can be used, including next/image component.

hero
Orientation
Scale1.8
Delay1.0s

Installation

Install the package with your favorite package manager:

Npm
npm install simple-parallax-js

Import it:

React
import SimpleParallax from "simple-parallax-js";

Initialization

Simply add the following JavaScript code:

React
import SimpleParallax from "simple-parallax-js";

const Component = () => (
  <SimpleParallax>
    <img src="image.jpg" alt="image" />
  </SimpleParallax>
)

Settings

nametypedefaulthint
orientation
Stringupup - right - down - left - up left - up right - down left - left right
scale
Number1.4need to be above 1.0
overflow
Booleanfalse
delay
Number0.4the delay is in second
transition
String'cubic-bezier(0,0,0,1)'any CSS transition
maxTransition
Number0it should be a percentage between 1 and 99
srcVanilla
StringnullVanilla version only
customContainerVanilla
String or NodenullVanilla version only
customWrapperVanilla
StringnullVanilla version only

Property Details

  • orientation

    Stringdefault up

    hint: up - right - down - left - up left - up right - down left - left right

    This is the orientation (or direction) of the parallax effect. Choose up and when scrolling down, the image will translate from the bottom to the top (so the image will translate up). When scrolling up, the image will translate from the top to the bottom. Same logic applies for all other orientations (right, down, left, up left, up right, down left, or down right). When 2 directions are combined (for example down right), the image will translate diagonally.

    See example
  • scale

    Numberdefault 1.4

    hint: need to be above 1.0

    The higher the scale is set, the more visible the parallax effect will be. In return, the image will lose in quality. To reduce the lossless effect, if the scale is set at 1.5 and your image is 500px width, do the simple math 500 * 1.5 = 750. So you can choose a 750px image to replace your 500px one and don't see any quality leak. More information is available if you read the case study here.

    See example
  • overflow

    Booleandefault false

    By default, the image is scaled to apply a parallax effect without any overflow on the layout - you can check the case study to have a better understanding. When overflow is set to true, the image will translate out of its natural flow (so it may overlap with your content).

    See example
  • delay

    Numberdefault 0.4

    hint: the delay is in second

    When a delay is set, the translation of the image will continue during that delay when the user stops scrolling. That gives a very nice effect. The delay is in second.

    See example
  • transition

    Stringdefault 'cubic-bezier(0,0,0,1)'

    hint: any CSS transition

    The transition setting works closely with the delay setting. This setting will add any CSS transition to the delay setting. For example, you can use ease or ease-in-out.

    See example
  • maxTransition

    Numberdefault 0

    hint: it should be a percentage between 1 and 99

    The maxTransition setting should be used to stop the parallax animation after a given percentage. By default, it translates from 0% to 100% of the user viewport. You can change it here to any percentage you want.

    See example
  • src

    Stringdefault nullVanilla only

    This is the source of the image. It can be a local path or a URL.

  • customContainer

    String or Nodedefault nullVanilla only

    By default, the parallax calculation is done with the body scroll percentage. In some cases, the images may be in a container that has its own scroll area, so to have an accurate calculation, the custom container should be set.

  • customWrapper

    Stringdefault nullVanilla only

    In some cases, you want to use your own wrapper instead of the one created by the plugin. If you specify your custom wrapper, the plugin will add the simpleParallax class along with an overflow: hidden style.

Methods

Refresh a simpleParallax instance (to recalculate all the positions) :Vanilla version only

Javascript
var images = document.querySelectorAll('img');
var instance = new simpleParallax(images);
instance.destroy();

Destroy a simpleParallax instance Vanilla version only

Javascript
var images = document.querySelectorAll('img');
var instance = new simpleParallax(images);
instance.destroy();

Examples

  • Basic config

    Basic config
    React
    import SimpleParallax from "simple-parallax-js";
    
    const Component = () => (
      <SimpleParallax>
        <img src={"thumbnail.jpg"} alt={"image"} />
      </SimpleParallax>
    )
  • with a different direction

    with a different direction
    React
    import SimpleParallax from "simple-parallax-js";
    
    const Component = () => (
      <SimpleParallax orientation="right">
        <img src={"thumbnail.jpg"} alt={"image"} />
      </SimpleParallax>
    )
  • with a higher scale

    with a higher scale
    React
    import SimpleParallax from "simple-parallax-js";
    
    const Component = () => (
      <SimpleParallax scale={1.7}>
        <img src={"thumbnail.jpg"} alt={"image"} />
      </SimpleParallax>
    )
  • with overflow

    with overflow
    React
    import SimpleParallax from "simple-parallax-js";
    
    const Component = () => (
      <SimpleParallax overflow>
        <img src={"thumbnail.jpg"} alt={"image"} />
      </SimpleParallax>
    )
  • with delay and transition

    with delay and transition
    React
    import SimpleParallax from "simple-parallax-js";
    
    const Component = () => (
      <SimpleParallax delay={1} transition="cubic-bezier(0,0,0,1)">
        <img src={"thumbnail.jpg"} alt={"image"} />
      </SimpleParallax>
    )
  • with maxTransition

    with maxTransition
    React
    import SimpleParallax from "simple-parallax-js";
    
    const Component = () => (
      <SimpleParallax maxTransition={40}>
        <img src={"thumbnail.jpg"} alt={"image"} />
      </SimpleParallax>
    )

Support the project

If you like simpleParallax.js, please consider supporting the project by giving it a star on GitHub.