-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
42 lines (35 loc) · 1.22 KB
/
script.js
File metadata and controls
42 lines (35 loc) · 1.22 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
function debounce(func, wait = 10) {
let timeout;
return function () {
clearTimeout(timeout);
timeout = setTimeout(() => {
func.apply(this, arguments);
}, wait);
};
}
function slideElements() {
const slideElements = document.querySelectorAll('.slide');
slideElements.forEach(element => {
const slideInAt = (window.scrollY + window.innerHeight) - element.offsetHeight / 2;
const elementBottom = element.offsetTop + element.offsetHeight;
const isHalfShown = slideInAt > element.offsetTop;
const isNotScrolledPast = window.scrollY < elementBottom;
if (isHalfShown && isNotScrolledPast) {
element.classList.add('active');
} else {
element.classList.remove('active');
}
});
}
window.addEventListener('scroll', debounce(slideElements));
window.addEventListener('DOMContentLoaded', function() {
const fadeElements = document.querySelectorAll('.fade-in');
function fadeInElements() {
fadeElements.forEach(function(element, index) {
setTimeout(function() {
element.style.opacity = 1;
}, index * 200); // Ajuste o valor do atraso entre cada item (em milissegundos)
});
}
fadeInElements();
});