WedX - журнал о программировании и компьютерных науках

Как React сохраняет состояние компонента?

Это своего рода вопрос о внутренностях react.js. Вот как я понимаю виртуальный дом.

old  (rendered from component <X/>)        new (rendered from component <X/>)
null                                       <div>
                                            <AnotherComponent/> <- state {count:0}
                                            <p>{this.state.text}</p>
                                           </div>

при сравнении функция видит, что старый снимок пустой. мы создаем свои элементы, и элементы из компонента <AnotherComponent/>.

old  (rendered from component <X/>)        new (rendered from component <X/>)
<div>                                      <div>
 <AnotherComponent/> <- state {count:1}     <AnotherComponent/> <- state {count:0} ?
 <p>Lorem ipsum</p>                         <p>Lorem ...</p> <- state updates
</div>                                     </div>

допустим, компонент <X/> обновляется во второй раз, а <AnotherComponent/> изменил свое состояние до обновления родителя.

хорошо, я сравниваю два снимка, применяю изменения. но <AnotherComponent/> сбросит свое состояние и у меня будет {count:0} вместо {count:1}.

как react.js или любая другая декларативная библиотека js для создания пользовательского интерфейса делают такие вещи. может я что-то не так понимаю.

я думаю, мне нужно получить состояние старого компонента и назначить его новому компоненту. это правильный способ сделать это? Спасибо!


  • Компонент будет создавать виртуальный DOM при изменении его внутреннего состояния или при изменении реквизита. React сравнивает это с предыдущим циклом рендеринга и соответствующим образом обновляет DOM. Функциональные компоненты всегда будут перерисовываться, если они не обернуты в React.memo. Внутреннее состояние компонента также изменяется, когда он использует context или redux connect/useSelector и контекст или результат изменений connect/useSelector. 27.03.2020

Ответы:


1

Насколько мне известно, React использует замыкание для захвата состояния. между повторными рендерами.

27.03.2020
Новые материалы

Объяснение документов 02: BERT
BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..

Учебные заметки: создание моего первого пакета Node.js
Это мои обучающие заметки, когда я научился создавать свой самый первый пакет Node.js, распространяемый через npm. Оглавление Глоссарий I. Новый пакет 1.1 советы по инициализации..

Забудьте о Matplotlib: улучшите визуализацию данных с помощью умопомрачительных функций Seaborn!
Примечание. Эта запись в блоге предполагает базовое знакомство с Python и концепциями анализа данных. Привет, энтузиасты данных! Добро пожаловать в мой блог, где я расскажу о невероятных..


Для любых предложений по сайту: [email protected]