Наблюдатель по пересечению для двух элементовJavascript

Форум по Javascript
Ответить
Anonymous
 Наблюдатель по пересечению для двух элементов

Сообщение Anonymous »

Я начал с ситуации, когда я хотел наблюдать за элементом на моей странице, давайте назовем его «триггер». Обычно он всегда виден при загрузке страницы (выше сгиба). < /P>
, когда мы прокручиваем вниз, если «триггер» больше не виден, я хочу применить класс CSS к другому элементу.const trigger = document.getElementById('trigger')
const otherElement = document.getElementById('some-other-element')

const intersectionObserver = new IntersectionObserver(
([entry]) => {
if (entry.intersectionRatio === 0) {
otherElement.classList.add('special-class')
} else if (entry.intersectionRatio === 1) {
otherElement.classList.remove('special-class')
}
},
{
threshold: [0, 1],
},
)

intersectionObserver.observe(trigger)
< /code>
После тестирования этого я понял, что пользователи могут иметь меньшие устройства, и в этом случае нижний край устройства на самом деле выше, где «триггер» сидит так на странице, «триггер» фактически не виден. Таким образом, мой «специальный класс» применяется автоматически, что не то, что я хочу, чтобы произошло. Тем не менее, я не мог понять, как получить recsectionObserver, чтобы наблюдать как элементы, так и как мой код будет соответственно.

Подробнее здесь: https://stackoverflow.com/questions/797 ... o-elements
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Javascript»