PS: мне нужно перезапускать анимацию каждый раз, когда я нахожусь в области просмотра раздела. .
PSS: enter.target.classList.remove('animate__animated', enter.target.dataset.animation); похоже, проблема в этом.
вот мой код:
Код: Выделить всё
Document
body{margin: 0;}
.hidden{opacity: 0;}
#div{background-color: aliceblue; width: 100vw; height: 100vh;}
#h1{height: 100vh; width: 100vw;}
XXXXXXXXX
XXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
XXXXXXXXXXXXXXXXXXXXXXXX
document.addEventListener('DOMContentLoaded', () => {
const sections = document.querySelectorAll('.hidden');
const observerOptions = {
threshold: 0.5
};
const observerCallback = (entries, observer) => {
entries.forEach(entry => {
console.log(entry.isIntersecting)
if (entry.isIntersecting) {
entry.target.classList.remove('hidden');
entry.target.classList.add('animate__animated', entry.target.dataset.animation);
} else {
entry.target.classList.add('hidden');
entry.target.classList.remove('animate__animated', entry.target.dataset.animation);
}
});
};
const observer = new IntersectionObserver(observerCallback, observerOptions);
sections.forEach(section => {
observer.observe(section);
});
});
Подробнее здесь: https://stackoverflow.com/questions/786 ... -intersect