169 похожих чатов

Всем привет есть у кого нибудь функция для слежения за скроллом

вверх/вниз?
у меня есть одна, на маке и устройствах от эпла все отлично работает (айфон, мак и тд)
на андроидах или винде не работает

сама суть в чем
если мы скроллим вниз, то скрываем хэдэр, если начинаем скроллить вверх, то хэдэр нужно показывать

7 ответов

3 просмотра

addEventListener('scroll', e => {})

Стикер

Привет! Конечно, я могу предоставить вам пример функции на JavaScript для отслеживания направления скролла и скрытия/показа хэдера в зависимости от этого направления. Вот как это может выглядеть: ```javascript let prevScrollPos = window.pageYOffset; const header = document.querySelector('header'); // Замените селектор на свой window.addEventListener('scroll', () => { const currentScrollPos = window.pageYOffset; if (prevScrollPos > currentScrollPos) { // Скрываем хэдер при скролле вверх header.style.transform = 'translateY(0)'; } else { // Показываем хэдер при скролле вниз header.style.transform = `translateY(-${header.offsetHeight}px)`; } prevScrollPos = currentScrollPos; }); ``` Вы можете вставить этот код в вашу веб-страницу внутри тега <script></script>. Обратите внимание, что здесь используется простой механизм сравнения текущей позиции скролла с предыдущей, чтобы определить направление скролла. Если у вас есть конкретные требования к анимации или поведению, вы можете адаптировать этот код под ваши нужды. Не забудьте заменить document.querySelector('header') на селектор, который соответствует вашему хэдеру на веб-странице.

А нельзя тупо отслеживать направление скролла и от этого хедер показывать? Зачем такая нетривиальная логика?

Stranger
А нельзя тупо отслеживать направление скролла и от...

Нет ничего нетривиального, именно это и делается в примере, просто кроме условия вверх/вниз добавлено условие минмального отступа

Влад- Автор вопроса
Vladimir
screenshot

оно в целом работает, но по какой то причине если немного проскроллить, то оно зацикливается и меняет true/false постоянно

Похожие вопросы

Обсуждают сегодня

Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
generic procedure function test<T>(param: T); type case T of longint: NewT = word; longword: NewT = byte; end; var v1: NewT; Как это можно сделать? Чтобы у меня...
notme
21
Делал задачу вот такую https://stepik.org/lesson/4985/step/9?unit=1083 получилось такое https://play.haskell.org/saved/ipKrepqe оно работает, тестов много не писал, но работае...
Fedor
22
Всем добрый вечер. Нужна помощь с прикруткой telegram-vapor-bot к проекту Vapor. Удалось после старта приложения отправить тестовое сообщение в бот, вот только сразу после это...
advanc3d
3
program Project1; procedure generic_proc<T>(); begin end; begin generic_proc<Int64>(0); end. Я чет не понял, а как в Delphi сделать такое? процедуру-дженерик... PS: а на...
notme
10
Кстати, что FPC мешает сделать нормальные проперти в юнитаз, завызанные на переменные? Нет, инлайнинг геттеров и геттеров кажется работает в принципе, но это же сколько лишн...
Arioch The
8
Хотел уточнить: копирование из одного рекорда в другой однотипный рекорд можно только по полям отдельно или можно чохом, типа Assign?
Ed Doc
9
Sometimes I like to solve problems the hard way. What do I mean? You know many problems can be fixed by restarting the system, but how much do you learn about the system? P...
Matthias Hoffmann
2
Похоже опять туплю задача https://stepik.org/lesson/5431/step/8?unit=1132 код и его работа https://play.haskell.org/saved/lmYTShXM на мой взгляд все правильно, и даже избыто...
Fedor
8
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Карта сайта