@historydev
Острая аллергия на анимешников

Как отключить скролл при условии что состояние не изменилось?

Здравствуйте. Реализовал чатик, подгружаю по 20 сообщений при прокрутке вверх, при достижении 0 я кручу вниз на 20 сообщений чтобы юзер попал туда, где остановился. Однако попал в ситуацию что сообщения закончились, а меня каждый раз отбрасывает на 20 назад. Как это исправить?

prevMessages - дополнительно подгруженные сообщения
messagesBox - элемент с сообщениями

useEffect(() => {
        if(messagesBox) {
            messagesBox.onscroll = (e) => {
                if(e.target.scrollTop < 1) {
                    e.target.scrollTo(0, e.target.querySelector('.direct-chat-msg:nth-child(20)').offsetTop);
                    const msgID = prevMessages.length ? parseInt(prevMessages[0].id) : parseInt(messages[0].id);
                    socket.emit('getPrevMessages', {roomId, msgID});
                }
                e.preventDefault();
            }
        }
    }, [prevMessages]);


Спасибо.
  • Вопрос задан
  • 49 просмотров
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
18 мая 2024, в 22:58
3000 руб./за проект
18 мая 2024, в 21:07
5000 руб./за проект
18 мая 2024, в 20:58
5000 руб./за проект