Я пытаюсь добавлять и удалять классы Animate.css в разделы моей веб-страницы в зависимости от их видимости в области просмотра. Я использую IntersectionObserver, чтобы определять, когда разделы входят в область просмотра и покидают ее. Однако после того, как я достиг области просмотра раздела, классы Animate.css начинают включаться и выключаться.
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);
});
});
Я пытался изменить параметры IF на более конкретные, изменить eventListener с помощью прокрутки, но это не то, что мне нужно.
также я поигрался с опциями ObserverOptions и нашел способ отложить это, но это довольно медленно, и если оно меньше 500, функция продолжает вызываться
const observerOptions = {
delay:500,
threshold: 0.5
};
Подробнее здесь: https://stackoverflow.com/questions/786 ... -intersect
Как включать и отключать классы Animate.css в зависимости от видимости с помощью IntersectionObserver в JavaScript? ⇐ CSS
Разбираемся в CSS
1719238853
Anonymous
Я пытаюсь добавлять и удалять классы Animate.css в разделы моей веб-страницы в зависимости от их видимости в области просмотра. Я использую IntersectionObserver, чтобы определять, когда разделы входят в область просмотра и покидают ее. Однако после того, как я достиг области просмотра раздела, классы Animate.css начинают включаться и выключаться.
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);
});
});
Я пытался изменить параметры IF на более конкретные, изменить eventListener с помощью прокрутки, но это не то, что мне нужно.
также я поигрался с опциями ObserverOptions и нашел способ отложить это, но это довольно медленно, и если оно меньше 500, функция продолжает вызываться
const observerOptions = {
delay:500,
threshold: 0.5
};
Подробнее здесь: [url]https://stackoverflow.com/questions/78662298/how-to-toggle-animate-css-classes-on-and-off-based-on-visibility-using-intersect[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия