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: 598
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:

  1. <div class="site-wrap">
  2. <h1>Slide in on Scroll</h1>
  3.  
  4. <p>
  5. Consectetur adipisicing elit. Tempore tempora rerum, est autem
  6. cupiditate, corporis a qui libero ipsum delectus quidem dolor at nulla,
  7. adipisci veniam in reiciendis aut asperiores omnis blanditiis quod quas
  8. laborum nam! Fuga ad tempora in aspernatur pariaturlores sunt esse
  9. magni, ut, dignissimos.
  10. </p>
  11. <p>
  12. Lorem ipsum cupiditate, corporis a qui libero ipsum delectus quidem
  13. dolor at nulla, adipisci veniam in reiciendis aut asperiores omnis
  14. blanditiis quod quas laborum nam! Fuga ad tempora in aspernatur pariatur
  15. fugit quibusdam dolores sunt esse magni, ut, dignissimos.
  16. </p>
  17. <p>Adipisicing elit. Tempore tempora rerum..</p>
  18. <p>
  19. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
  20. tempora rerum, est autem cupiditate, corporis a qui libero ipsum
  21. delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
  22. asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
  23. aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
  24. dignissimos.
  25. </p>
  26. <p>
  27. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
  28. tempora rerum, est autem cupiditate, corporis a qui libero ipsum
  29. delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
  30. asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
  31. aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
  32. dignissimos.
  33. </p>
  34. <p>
  35. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Tempore
  36. tempora rerum, est autem cupiditate, corporis a qui libero ipsum
  37. delectus quidem dolor at nulla, adipisci veniam in reiciendis aut
  38. asperiores omnis blanditiis quod quas laborum nam! Fuga ad tempora in
  39. aspernatur pariatur fugit quibusdam dolores sunt esse magni, ut,
  40. dignissimos.
  41. </p>
  42.  
  43. <img src="https://unsplash.it/400/400" class="align-left slide-in" />
  44.  
  45. <p>
  46. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Voluptates,
  47. deserunt facilis et iste corrupti omnis tenetur est. Iste ut est dicta
  48. dolor itaque adipisci, dolorum minima, veritatis earum provident error
  49. molestias. Ratione magni illo sint vel velit ut excepturi consectetur
  50. suscipit, earum modi accusamus voluptatem nostrum, praesentium numquam,
  51. reiciendis voluptas sit id quisquam. Consequatur in quis reprehenderit
  52. modi perspiciatis necessitatibus saepe, quidem, suscipit iure natus
  53. dignissimos ipsam, eligendi deleniti accusantium, rerum quibusdam fugit
  54. perferendis et optio recusandae sed ratione. Culpa, dolorum
  55. reprehenderit harum ab voluptas fuga, nisi eligendi natus maiores illum
  56. quas quos et aperiam aut doloremque optio maxime fugiat doloribus. Eum
  57. dolorum expedita quam, nesciunt
  58. </p>
  59.  
  60. <img src="https://unsplash.it/400/401" class="align-right slide-in" />
  61.  
  62. <p>
  63. at provident praesentium atque quas rerum optio dignissimos repudiandae
  64. ullam illum quibusdam. Vel ad error quibusdam, illo ex totam placeat.
  65. Quos excepturi fuga, molestiae ea quisquam minus, ratione dicta
  66. consectetur officia omnis, doloribus voluptatibus? Veniam ipsum
  67. veritatis architecto, provident quas consequatur doloremque quam quidem
  68. earum expedita, ad delectus voluptatum, omnis praesentium nostrum qui
  69. aspernatur ea eaque adipisci et cumque ab? Ea voluptatum dolore itaque
  70. odio. Eius minima distinctio harum, officia ab nihil exercitationem.
  71. Tempora rem nemo nam temporibus molestias facilis minus ipsam quam
  72. doloribus consequatur debitis nesciunt tempore officiis aperiam
  73. quisquam, molestiae voluptates cum, fuga culpa. Distinctio accusamus
  74. quibusdam, tempore perspiciatis dolorum optio facere consequatur quidem
  75. ullam beatae architecto, ipsam sequi officiis dignissimos amet impedit
  76. natus necessitatibus tenetur repellendus dolor rem! Dicta dolorem, iure,
  77. facilis illo ex nihil ipsa amet officia, optio temporibus eum autem odit
  78. repellendus nisi. Possimus modi, corrupti error debitis doloribus dicta
  79. libero earum, sequi porro ut excepturi nostrum ea voluptatem nihil
  80. culpa? Ullam expedita eligendi obcaecati reiciendis velit provident
  81. omnis quas qui in corrupti est dolore facere ad hic, animi soluta
  82. assumenda consequuntur reprehenderit! Voluptate dolor nihil veniam
  83. laborum voluptas nisi pariatur sed optio accusantium quam consectetur,
  84. corrupti, sequi et consequuntur, excepturi doloremque. Tempore quis
  85. velit corporis neque fugit non sequi eaque rem hic. Facere, inventore,
  86. aspernatur. Accusantium modi atque, asperiores qui nobis soluta cumque
  87. suscipit excepturi possimus doloremque odit saepe perferendis temporibus
  88. molestiae nostrum voluptatum quis id sint quidem nesciunt culpa. Rerum
  89. labore dolor beatae blanditiis praesentium explicabo velit optio esse
  90. aperiam similique, voluptatem cum, maiores ipsa tempore. Reiciendis sed
  91. culpa atque inventore, nam ullam enim expedita consectetur id velit
  92. iusto alias vitae explicabo nemo neque odio reprehenderit soluta sint
  93. eaque. Aperiam, qui ut tenetur, voluptate doloremque officiis dicta
  94. quaerat voluptatem rerum natus magni. Eum amet autem dolor ullam.
  95. </p>
  96.  
  97. <img src="https://unsplash.it/200/500" class="align-left slide-in" />
  98.  
  99. <p>
  100. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
  101. maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
  102. Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
  103. voluptatibus expedita quia vero perferendis, deserunt et incidunt
  104. eveniet
  105. <img src="https://unsplash.it/200/200" class="align-right slide-in" />
  106. temporibus doloremque possimus facilis. Possimus labore, officia dolore!
  107. Eaque ratione saepe, alias harum laboriosam deserunt laudantium
  108. blanditiis eum explicabo placeat reiciendis labore iste sint.
  109. Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
  110. eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
  111. consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
  112. rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
  113. aliquid laboriosam architecto at cupiditate commodi expedita in, quae
  114. blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
  115. culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
  116. corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
  117. Laboriosam rem, ratione. Autem blanditiis
  118. </p>
  119.  
  120. <p>
  121. laborum neque repudiandae quam, cumque, voluptate veritatis itaque,
  122. placeat veniam ad nisi. Expedita, laborum reprehenderit ratione soluta
  123. velit natus, odit mollitia. Corporis rerum minima fugiat in nostrum.
  124. Assumenda natus cupiditate hic quidem ex, quas, amet ipsum esse dolore
  125. facilis beatae maxime qui inventore, iste? Maiores dignissimos dolore
  126. culpa debitis voluptatem harum, excepturi enim reiciendis, tempora ab
  127. ipsam illum aspernatur quasi qui porro saepe iure sunt eligendi tenetur
  128. quaerat ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati
  129. officiis quo, ratione eveniet, provident pariatur. Veniam quasi expedita
  130. distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
  131. facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
  132. perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
  133. distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
  134. vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
  135. reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
  136. odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
  137. porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
  138. facere ducimus accusantium eos veritatis neque.
  139. </p>
  140.  
  141. <img src="https://unsplash.it/400/400" class="align-right slide-in" />
  142.  
  143. <p>
  144. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
  145. maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
  146. Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
  147. voluptatibus expedita quia vero perferendis, deserunt et incidunt
  148. eveniet temporibus doloremque possimus facilis. Possimus labore, officia
  149. dolore! Eaque ratione saepe, alias harum laboriosam deserunt laudantium
  150. blanditiis eum explicabo placeat reiciendis labore iste sint.
  151. Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
  152. eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
  153. consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
  154. rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
  155. aliquid laboriosam architecto at cupiditate commodi expedita in, quae
  156. blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
  157. culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
  158. corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
  159. Laboriosam rem, ratione. Autem blanditiis laborum neque repudiandae
  160. quam, cumque, voluptate veritatis itaque, placeat veniam ad nisi.
  161. Expedita, laborum reprehenderit ratione soluta velit natus, odit
  162. mollitia. Corporis rerum minima fugiat in nostrum. Assumenda natus
  163. cupiditate hic quidem ex, quas, amet ipsum esse dolore facilis beatae
  164. maxime qui inventore, iste? Maiores dignissimos dolore culpa debitis
  165. voluptatem harum, excepturi enim reiciendis, tempora ab ipsam illum
  166. aspernatur quasi qui porro saepe iure sunt eligendi tenetur quaerat
  167. ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati officiis
  168. quo, ratione eveniet, provident pariatur. Veniam quasi expedita
  169. distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
  170. facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
  171. perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
  172. distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
  173. vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
  174. reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
  175. odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
  176. porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
  177. facere ducimus accusantium eos veritatis neque.
  178. </p>
  179. <p>
  180. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Distinctio
  181. maiores adipisci quibusdam repudiandae dolor vero placeat esse sit!
  182. Quibusdam saepe aperiam explicabo placeat optio, consequuntur nihil
  183. voluptatibus expedita quia vero perferendis, deserunt et incidunt
  184. eveniet temporibus doloremque possimus facilis. Possimus labore, officia
  185. dolore! Eaque ratione saepe, alias harum laboriosam deserunt laudantium
  186. blanditiis eum explicabo placeat reiciendis labore iste sint.
  187. Consectetur expedita dignissimos, non quos distinctio, eos rerum facilis
  188. eligendi. Asperiores laudantium, rerum ratione consequatur, culpa
  189. consectetur possimus atque ab tempore illum non dolor nesciunt. Neque,
  190. rerum. A vel non incidunt, quod doloremque dignissimos necessitatibus
  191. aliquid laboriosam architecto at cupiditate commodi expedita in, quae
  192. blanditiis. Deserunt labore sequi, repellat laboriosam est, doloremque
  193. culpa reiciendis tempore excepturi. Enim nostrum fugit itaque vel
  194. corporis ullam sed tenetur ipsa qui rem quam error sint, libero.
  195. Laboriosam rem, ratione. Autem blanditiis laborum neque repudiandae
  196. quam, cumque, voluptate veritatis itaque, placeat veniam ad nisi.
  197. Expedita, laborum reprehenderit ratione soluta velit natus, odit
  198. mollitia. Corporis rerum minima fugiat in nostrum. Assumenda natus
  199. cupiditate hic quidem ex, quas, amet ipsum esse dolore facilis beatae
  200. maxime qui inventore, iste? Maiores dignissimos dolore culpa debitis
  201. voluptatem harum, excepturi enim reiciendis, tempora ab ipsam illum
  202. aspernatur quasi qui porro saepe iure sunt eligendi tenetur quaerat
  203. ducimus quas sequi omnis aperiam suscipit! Molestiae obcaecati officiis
  204. quo, ratione eveniet, provident pariatur. Veniam quasi expedita
  205. distinctio, itaque molestiae sequi, dolorum nisi repellendus quia
  206. facilis iusto dignissimos nam? Tenetur fugit quos autem nihil,
  207. perspiciatis expedita enim tempore, alias ab maiores quis necessitatibus
  208. distinctio molestias eum, quidem. Delectus impedit quidem laborum, fugit
  209. vel neque quo, ipsam, quasi aspernatur quas odio nihil? Veniam amet
  210. reiciendis blanditiis quis reprehenderit repudiandae neque, ab ducimus,
  211. odit excepturi voluptate saepe ipsam. Voluptatem eum error voluptas
  212. porro officiis, amet! Molestias, fugit, ut! Tempore non magnam, amet,
  213. facere ducimus accusantium eos veritatis neque.
  214. </p>
  215. </div>

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

  1. html {
  2. box-sizing: border-box;
  3. background: #ffc600;
  4. font-family: "helvetica neue";
  5. font-size: 20px;
  6. font-weight: 200;
  7. }
  8.  
  9. body {
  10. margin: 0;
  11. }
  12.  
  13. *,
  14. *:before,
  15. *:after {
  16. box-sizing: inherit;
  17. }
  18.  
  19. h1 {
  20. margin-top: 0;
  21. }
  22.  
  23. .site-wrap {
  24. max-width: 700px;
  25. margin: 100px auto;
  26. background: white;
  27. padding: 40px;
  28. text-align: justify;
  29. }
  30.  
  31. .align-left {
  32. float: left;
  33. margin-right: 20px;
  34. }
  35.  
  36. .align-right {
  37. float: right;
  38. margin-left: 20px;
  39. }
  40.  
  41. .slide-in {
  42. opacity: 0;
  43. transition: all 0.5s;
  44. }
  45.  
  46. .align-left.slide-in {
  47. transform: translateX(-30%) scale(0.95);
  48. }
  49.  
  50. .align-right.slide-in {
  51. transform: translateX(30%) scale(0.95);
  52. }
  53.  
  54. .slide-in.active {
  55. opacity: 1;
  56. transform: translateX(0%) scale(1);
  57. }

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:

  1. function debounce(func, wait = 20, immediate = true) {
  2. var timeout;
  3. return function() {
  4. var context = this,
  5. args = arguments;
  6. var later = function() {
  7. timeout = null;
  8. if (!immediate) func.apply(context, args);
  9. };
  10. var callNow = immediate && !timeout;
  11. clearTimeout(timeout);
  12. timeout = setTimeout(later, wait);
  13. if (callNow) func.apply(context, args);
  14. };
  15. }
  16.  
  17. const sliderImages = document.querySelectorAll(".slide-in");
  18.  
  19. function checkSlide(e) {
  20. sliderImages.forEach(sliderImage => {
  21. // half way through the image
  22. const slideInAt =
  23. window.scrollY + window.innerHeight - sliderImage.height / 2;
  24. // bottom of the image
  25. const imageBottom = sliderImage.offsetTop + sliderImage.height;
  26. const isHalfShown = slideInAt > sliderImage.offsetTop;
  27. const isNotScrolledPast = window.scrollY < imageBottom;
  28.  
  29. if (isHalfShown && isNotScrolledPast) {
  30. sliderImage.classList.add("active");
  31. } else {
  32. sliderImage.classList.remove("active");
  33. }
  34. });
  35. }
  36.  
  37. 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