Animate when Scrolled into View JavaScript

Animate when Scrolled into View JavaScript
Code Snippet:Slide in on Scroll
Author: Aleksandar Sandro Cvetković
Published: January 14, 2024
Last Updated: January 22, 2024
Downloads: 451
License: MIT
Edit Code online: View on CodePen
Read More

This JavaScript code allows elements with the class “slide-in” to animate when scrolled into view. It works by detecting when an element is halfway visible in the viewport and then applies an animation. This functionality is helpful for creating engaging and interactive web pages.

You can use this code on your website to add subtle animations to elements as users scroll down the page. It enhances the user experience by making your content more engaging and interactive.

How to Animate When Scrolled Into View Using JavaScript

1. First, create the HTML structure of your webpage. Ensure you have the elements you want to animate with the “slide-in” class. Here’s a basic example:

<div class="site-wrap">
      <h1>Slide in on Scroll</h1>

      <p>
        Consectetur adipisicing elit. Tempore tempora rerum, est autem
        cupiditate, corporis a qui libero ipsum delectus quidem dolor at nulla,
        adipisci veniam in reiciendis aut asperiores omnis blanditiis quod quas
        laborum nam! Fuga ad tempora in aspernatur pariaturlores sunt esse
        magni, ut, dignissimos.
      </p>
      <p>
        Lorem ipsum cupiditate, corporis a qui libero ipsum delectus quidem
        dolor at nulla, adipisci veniam in reiciendis aut asperiores omnis
        blanditiis quod quas laborum nam! Fuga ad tempora in aspernatur pariatur
        fugit quibusdam dolores sunt esse magni, ut, dignissimos.
      </p>
      <p>Adipisicing elit. Tempore tempora rerum..</p>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
        tempora rerum, est autem cupiditate, corporis a qui libero ipsum
        delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
        asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
        aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
        dignissimos.
      </p>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
        tempora rerum, est autem cupiditate, corporis a qui libero ipsum
        delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
        asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
        aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
        dignissimos.
      </p>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
        tempora rerum, est autem cupiditate, corporis a qui libero ipsum
        delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
        asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
        aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
        dignissimos.
      </p>

      <img src="https://unsplash.it/400/400" class="align-left slide-in" />

      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Voluptates,
        deserunt facilis et iste corrupti omnis tenetur est. Iste ut est dicta
        dolor itaque adipisci, dolorum minima, veritatis earum provident error
        molestias. Ratione magni illo sint vel velit ut excepturi consectetur
        suscipit, earum modi accusamus voluptatem nostrum, praesentium numquam,
        reiciendis voluptas sit id quisquam. Consequatur in quis reprehenderit
        modi perspiciatis necessitatibus saepe, quidem, suscipit iure natus
        dignissimos ipsam, eligendi deleniti accusantium, rerum quibusdam fugit
        perferendis et optio recusandae sed ratione. Culpa, dolorum
        reprehenderit harum ab voluptas fuga, nisi eligendi natus maiores illum
        quas quos et aperiam aut doloremque optio maxime fugiat doloribus. Eum
        dolorum expedita quam, nesciunt
      </p>

      <img src="https://unsplash.it/400/401" class="align-right slide-in" />

      <p>
        at provident praesentium atque quas rerum optio dignissimos repudiandae
        ullam illum quibusdam. Vel ad error quibusdam, illo ex totam placeat.
        Quos excepturi fuga, molestiae ea quisquam minus, ratione dicta
        consectetur officia omnis, doloribus voluptatibus? Veniam ipsum
        veritatis architecto, provident quas consequatur doloremque quam quidem
        earum expedita, ad delectus voluptatum, omnis praesentium nostrum qui
        aspernatur ea eaque adipisci et cumque ab? Ea voluptatum dolore itaque
        odio. Eius minima distinctio harum, officia ab nihil exercitationem.
        Tempora rem nemo nam temporibus molestias facilis minus ipsam quam
        doloribus consequatur debitis nesciunt tempore officiis aperiam
        quisquam, molestiae voluptates cum, fuga culpa. Distinctio accusamus
        quibusdam, tempore perspiciatis dolorum optio facere consequatur quidem
        ullam beatae architecto, ipsam sequi officiis dignissimos amet impedit
        natus necessitatibus tenetur repellendus dolor rem! Dicta dolorem, iure,
        facilis illo ex nihil ipsa amet officia, optio temporibus eum autem odit
        repellendus nisi. Possimus modi, corrupti error debitis doloribus dicta
        libero earum, sequi porro ut excepturi nostrum ea voluptatem nihil
        culpa? Ullam expedita eligendi obcaecati reiciendis velit provident
        omnis quas qui in corrupti est dolore facere ad hic, animi soluta
        assumenda consequuntur reprehenderit! Voluptate dolor nihil veniam
        laborum voluptas nisi pariatur sed optio accusantium quam consectetur,
        corrupti, sequi et consequuntur, excepturi doloremque. Tempore quis
        velit corporis neque fugit non sequi eaque rem hic. Facere, inventore,
        aspernatur. Accusantium modi atque, asperiores qui nobis soluta cumque
        suscipit excepturi possimus doloremque odit saepe perferendis temporibus
        molestiae nostrum voluptatum quis id sint quidem nesciunt culpa. Rerum
        labore dolor beatae blanditiis praesentium explicabo velit optio esse
        aperiam similique, voluptatem cum, maiores ipsa tempore. Reiciendis sed
        culpa atque inventore, nam ullam enim expedita consectetur id velit
        iusto alias vitae explicabo nemo neque odio reprehenderit soluta sint
        eaque. Aperiam, qui ut tenetur, voluptate doloremque officiis dicta
        quaerat voluptatem rerum natus magni. Eum amet autem dolor ullam.
      </p>

      <img src="https://unsplash.it/200/500" class="align-left slide-in" />

      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
        maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
        Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
        voluptatibus expedita quia vero perferendis, deserunt et incidunt
        eveniet
        <img src="https://unsplash.it/200/200" class="align-right slide-in" />
        temporibus doloremque possimus facilis. Possimus labore, officia dolore!
        Eaque ratione saepe, alias harum laboriosam deserunt laudantium
        blanditiis eum explicabo placeat reiciendis labore iste sint.
        Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
        eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
        consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
        rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
        aliquid laboriosam architecto at cupiditate commodi expedita in, quae
        blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
        culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
        corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
        Laboriosam rem, ratione. Autem blanditiis
      </p>

      <p>
        laborum neque repudiandae quam, cumque, voluptate veritatis itaque,
        placeat veniam ad nisi. Expedita, laborum reprehenderit ratione soluta
        velit natus, odit mollitia. Corporis rerum minima fugiat in nostrum.
        Assumenda natus cupiditate hic quidem ex, quas, amet ipsum esse dolore
        facilis beatae maxime qui inventore, iste? Maiores dignissimos dolore
        culpa debitis voluptatem harum, excepturi enim reiciendis, tempora ab
        ipsam illum aspernatur quasi qui porro saepe iure sunt eligendi tenetur
        quaerat ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati
        officiis quo, ratione eveniet, provident pariatur. Veniam quasi expedita
        distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
        facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
        perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
        distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
        vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
        reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
        odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
        porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
        facere ducimus accusantium eos veritatis neque.
      </p>

      <img src="https://unsplash.it/400/400" class="align-right slide-in" />

      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
        maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
        Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
        voluptatibus expedita quia vero perferendis, deserunt et incidunt
        eveniet temporibus doloremque possimus facilis. Possimus labore, officia
        dolore! Eaque ratione saepe, alias harum laboriosam deserunt laudantium
        blanditiis eum explicabo placeat reiciendis labore iste sint.
        Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
        eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
        consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
        rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
        aliquid laboriosam architecto at cupiditate commodi expedita in, quae
        blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
        culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
        corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
        Laboriosam rem, ratione. Autem blanditiis laborum neque repudiandae
        quam, cumque, voluptate veritatis itaque, placeat veniam ad nisi.
        Expedita, laborum reprehenderit ratione soluta velit natus, odit
        mollitia. Corporis rerum minima fugiat in nostrum. Assumenda natus
        cupiditate hic quidem ex, quas, amet ipsum esse dolore facilis beatae
        maxime qui inventore, iste? Maiores dignissimos dolore culpa debitis
        voluptatem harum, excepturi enim reiciendis, tempora ab ipsam illum
        aspernatur quasi qui porro saepe iure sunt eligendi tenetur quaerat
        ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati officiis
        quo, ratione eveniet, provident pariatur. Veniam quasi expedita
        distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
        facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
        perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
        distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
        vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
        reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
        odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
        porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
        facere ducimus accusantium eos veritatis neque.
      </p>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
        maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
        Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
        voluptatibus expedita quia vero perferendis, deserunt et incidunt
        eveniet temporibus doloremque possimus facilis. Possimus labore, officia
        dolore! Eaque ratione saepe, alias harum laboriosam deserunt laudantium
        blanditiis eum explicabo placeat reiciendis labore iste sint.
        Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
        eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
        consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
        rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
        aliquid laboriosam architecto at cupiditate commodi expedita in, quae
        blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
        culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
        corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
        Laboriosam rem, ratione. Autem blanditiis laborum neque repudiandae
        quam, cumque, voluptate veritatis itaque, placeat veniam ad nisi.
        Expedita, laborum reprehenderit ratione soluta velit natus, odit
        mollitia. Corporis rerum minima fugiat in nostrum. Assumenda natus
        cupiditate hic quidem ex, quas, amet ipsum esse dolore facilis beatae
        maxime qui inventore, iste? Maiores dignissimos dolore culpa debitis
        voluptatem harum, excepturi enim reiciendis, tempora ab ipsam illum
        aspernatur quasi qui porro saepe iure sunt eligendi tenetur quaerat
        ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati officiis
        quo, ratione eveniet, provident pariatur. Veniam quasi expedita
        distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
        facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
        perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
        distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
        vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
        reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
        odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
        porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
        facere ducimus accusantium eos veritatis neque.
      </p>
    </div>

2. In your CSS, you can style your elements and define their initial appearance and animation properties.

html {
  box-sizing: border-box;
  background: #ffc600;
  font-family: "helvetica neue";
  font-size: 20px;
  font-weight: 200;
}

body {
  margin: 0;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

h1 {
  margin-top: 0;
}

.site-wrap {
  max-width: 700px;
  margin: 100px auto;
  background: white;
  padding: 40px;
  text-align: justify;
}

.align-left {
  float: left;
  margin-right: 20px;
}

.align-right {
  float: right;
  margin-left: 20px;
}

.slide-in {
  opacity: 0;
  transition: all 0.5s;
}

.align-left.slide-in {
  transform: translateX(-30%) scale(0.95);
}

.align-right.slide-in {
  transform: translateX(30%) scale(0.95);
}

.slide-in.active {
  opacity: 1;
  transform: translateX(0%) scale(1);
}

3. Now, you need to add the JavaScript code to make the animations work. This code includes a debouncing function and an event listener to trigger animations when the elements come into view. Add this JavaScript code to your webpage:

function debounce(func, wait = 20, immediate = true) {
  var timeout;
  return function() {
    var context = this,
      args = arguments;
    var later = function() {
      timeout = null;
      if (!immediate) func.apply(context, args);
    };
    var callNow = immediate && !timeout;
    clearTimeout(timeout);
    timeout = setTimeout(later, wait);
    if (callNow) func.apply(context, args);
  };
}

const sliderImages = document.querySelectorAll(".slide-in");

function checkSlide(e) {
  sliderImages.forEach(sliderImage => {
    // half way through the image
    const slideInAt =
      window.scrollY + window.innerHeight - sliderImage.height / 2;
    // bottom of the image
    const imageBottom = sliderImage.offsetTop + sliderImage.height;
    const isHalfShown = slideInAt > sliderImage.offsetTop;
    const isNotScrolledPast = window.scrollY < imageBottom;

    if (isHalfShown && isNotScrolledPast) {
      sliderImage.classList.add("active");
    } else {
      sliderImage.classList.remove("active");
    }
  });
}

window.addEventListener("scroll", debounce(checkSlide));

You can further customize your animations by modifying the CSS transitions and JavaScript logic. Adjust the animation speed, starting point, or any other desired effect.

That’s all! hopefully, you have successfully created functionality to animate when scrolled into view using JavaScript. If you have any questions or suggestions, feel free to comment below.

Leave a Comment

This site uses Akismet to reduce spam. Learn how your comment data is processed.

About CodeHim

Free Web Design Code & Scripts - CodeHim is one of the BEST developer websites that provide web designers and developers with a simple way to preview and download a variety of free code & scripts. All codes published on CodeHim are open source, distributed under OSD-compliant license which grants all the rights to use, study, change and share the software in modified and unmodified form. Before publishing, we test and review each code snippet to avoid errors, but we cannot warrant the full correctness of all content. All trademarks, trade names, logos, and icons are the property of their respective owners... find out more...

Please Rel0ad/PressF5 this page if you can't click the download/preview link

X