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.
Similar Code Snippets:

I code and create web elements for amazing people around the world. I like work with new people. New people new Experiences.
I truly enjoy what I’m doing, which makes me more passionate about web development and coding. I am always ready to do challenging tasks whether it is about creating a custom CMS from scratch or customizing an existing system.






