|
0 / 0 / 1
Регистрация: 11.05.2021
Сообщений: 92
|
|||||||||||
socket.io Дублирование сообщений в чате ReactJS App25.10.2022, 12:20. Показов 904. Ответов 9
Метки нет (Все метки)
Когда я отправляю сообщение, на первом клиенте(отправителе) все в порядке, сообщение не дублируется. Но у остальных пользователей комнаты (получателей) сообщение дублируется. В то же время, если войдет новый пользователь или какой-то пользователь перезайдет в комнату, повторяющихся сообщений не будет (я имею в виду старые сообщения. Новые также будут дублироваться). Пожалуйста, подскажите мне, как это исправить?
server.js
0
|
|||||||||||
| 25.10.2022, 12:20 | |
|
Ответы с готовыми решениями:
9
Вывод сообщений в чате Организовать сохранение сообщений в чате Ошибка - не видно сообщений в чате на Js |
|
Молодой техлид)
|
|||||||||||
| 25.10.2022, 15:23 | |||||||||||
Сообщение было отмечено Blakky как решение
Решение
Если react 18 и включен strict mode хук useEffect выполнится дважды
1
|
|||||||||||
|
0 / 0 / 1
Регистрация: 11.05.2021
Сообщений: 92
|
|
| 25.10.2022, 15:52 [ТС] | |
|
mr_dramm, попробовал. Теперь оно повторяется по 3 раза, а не 2.. Может, вы где-нибудь ошиблись?
0
|
|
|
0 / 0 / 1
Регистрация: 11.05.2021
Сообщений: 92
|
||||||
| 25.10.2022, 15:59 [ТС] | ||||||
|
mr_dramm, в addMessage добавил console.log('Сообщение отправлено', message), получил следующее: (картинка)
Как это пофиксить? :c (кусок reducer.js)
0
|
||||||
|
0 / 0 / 1
Регистрация: 11.05.2021
Сообщений: 92
|
|
| 25.10.2022, 16:18 [ТС] | |
|
в reducer, там где NEW_MESSAGE тоже прокинул console.log(). У отправителя 2 повтора, у получателя 4....
0
|
|
|
Молодой техлид)
|
|
| 25.10.2022, 16:26 | |
|
Я надеюсь вы сделали замену хука useEffect, а не добавили еще кода. Как могло получиться 3 вызова?
Ошибки с ключем пофиксите он итоже косвено могут задваивать сообщение. Ошибка с установкой соединения уже была или только появилась? Кажется нужно больше кода анализировать Добавлено через 3 минуты Ответьте сначала на вопрос у Вас React 18? или меньше версия? посмотреите в package json Добавлено через 1 минуту Если меньше 18 то мои правки просто бесполезны, они не должны были вообще никак повлиять ил можно не использовать
0
|
|
|
0 / 0 / 1
Регистрация: 11.05.2021
Сообщений: 92
|
|||||||||
| 25.10.2022, 16:50 [ТС] | |||||||||
|
Добавлено через 1 минуту Добавлено через 17 минут не знаю, вряд ли в chat.jsx проблема..
0
|
|||||||||
|
Молодой техлид)
|
||||||
| 25.10.2022, 17:00 | ||||||
|
добавьте тут key
1
|
||||||
|
0 / 0 / 1
Регистрация: 11.05.2021
Сообщений: 92
|
|
| 25.10.2022, 17:58 [ТС] | |
|
mr_dramm, подправил. теперь той ошибки в консоли нет, но сообщение по прежнему дублируется...
Добавлено через 20 минут mr_dramm, добавил потом ваш useeffect, и всё заработало! Спасибо огромное
0
|
|
|
Молодой техлид)
|
||||||
| 25.10.2022, 18:38 | ||||||
|
Если интересно про двойной запуск useEffect в режимеотладки на react 18 strict mode прочитать
Этот эффект срабатывает только при монтировании компонента т.е. когда у useEffect нет зависимостей
1
|
||||||
| 25.10.2022, 18:38 | |
|
Помогаю со студенческими работами здесь
10
Порядок отображения сообщений в чате
Непрерывное обновление сообщений в чате twitch bot не видит сообщений в чате
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Символьное дифференцирование
igorrr37 13.02.2026
/ *
Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет
значение производной при заданном х
Логарифм записывается как: (x-2)log(x^2+2) -. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога
Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
|
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
|