Форум программистов, компьютерный форум, киберфорум
React/ReactJS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 04.07.2020
Сообщений: 1

Компонент отрабатывает но не отображает изменения

04.07.2020, 07:24. Показов 1028. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите, это в reactе бага что компонент отрабатывает но не отображает изменения?
т.е. в компонент - стрелочаня функция, получает обновленное состояние (useState) вижу что отрабатывает но никак не обновляет DOM хотя там явно есть изменения?

Демо:
https://codesandbox.io/s/wild-... src/App.js
Попробуйте покликать по AnotherComponent и посмотреть в консоль
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.07.2020, 07:24
Ответы с готовыми решениями:

После изменения кода, отображает элементы до изменения
Ребята, помогите, такая проблема: есть корпоративный сайт написанный на ASP.NET работает через IIS Нужно изменить некоторые элементы...

Не отображает изменения при компиляции
Добрый день, делаю изменения на форме делфи, компилирую проект, а он мои изменения не показывает, показывает старый результат. подскажите в...

Почему не отрабатывает компонент ADO/Delphi запущенный под системной учетной записью?
Добрый день! Имеется рабочее приложение написанное на Delphi с компонентами ADO. Приложение берет инфо из лога и отправляет на сервак. ...

1
Модератор
Эксперт JS
 Аватар для Eva Rosalene
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
08.07.2020, 01:48
Это мерзкая бага/особенность, но благо она давно описана. Не благо, что она описана так мало и редко.
Всё дело в том, что реакт по-разному выполняет апдейт стейта/вдома и т.п. вещей в зависимости от того, вызван setState/dispatch (useReducer) в процессе исполнения обработчиков событий, навешиваемых реактом или в процессе исполнения асинхронного кода.
И фиксится оно так: https://codesandbox.io/s/conde... src/App.js (см. строку 16)
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
  const handler = useAction(name => {
    console.log("action");
    return action();
  });
  const wrappedHandler = useCallback(() => {
    return unstable_batchedUpdates(() => handler());
  }, [handler]);
  console.log("render App", value);
  return (
    <div className="App">
      <div onClick={wrappedHandler}>
        <h1>App Component</h1>
        <b>{value + ""}</b>
 
        <h2>Start editing to see some magic happen!</h2>
      </div>
      <Another value={value} onChange={wrappedHandler} />
    </div>
  );
Ну и баг-репорт стоит тоже завести. Я не вижу ни одной причины, почему синхронный рендер должен потерять данные, но - теряет. (batchedUpdates кроме пакетирования изменений стейта откладывает ререндер до исполнения всего, что в нём).
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.07.2020, 01:48
Помогаю со студенческими работами здесь

GitHub не корректно отображает изменения в файле
Добрый день! Ответвился от Дева. Сделал свои изменения, закомитил, запушил в репозиторий свою ветку с фиксом. Смотрю chenges в...

Компонент TDBGrid в Builder 4.0 не отображает строки
У меня проблема с компонентом DBGrid в Builder 4.0 когда показывают стобцы нормально но вот почему - то строки не отображает!. Отображает...

Компонент label не отображает круглые числа
пишу на action script 2.0 компоненту label присваивается переменная с числовым значением от 1 до 100. Если число не круглое, то оно...

Компонент который отображает HTML файл
Какой компонент использовать в Delphi чтобы потом туда поместить HTML файл?

Vue-router не отображает компонент по ссылке
Здравствуйте, столкнулся с определенной проблемой. Для перехода использую vue-router. Страницы описываю в файлах .vue. Так вот когда...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru