• Что бы вступить в ряды "Принятый кодер" Вам нужно:
    Написать 10 полезных сообщений или тем и Получить 10 симпатий.
    Для того кто не хочет терять время,может пожертвовать средства для поддержки сервеса, и вступить в ряды VIP на месяц, дополнительная информация в лс.

  • Пользаватели которые будут спамить, уходят в бан без предупреждения. Спам сообщения определяется администрацией и модератором.

  • Гость, Что бы Вы хотели увидеть на нашем Форуме? Изложить свои идеи и пожелания по улучшению форума Вы можете поделиться с нами здесь. ----> Перейдите сюда
  • Все пользователи не прошедшие проверку электронной почты будут заблокированы. Все вопросы с разблокировкой обращайтесь по адресу электронной почте : info@guardianelinks.com . Не пришло сообщение о проверке или о сбросе также сообщите нам.

Each child in a list should have a unique key prop

Lomanu4 Оффлайн

Lomanu4

Команда форума
Администратор
Регистрация
1 Мар 2015
Сообщения
1,481
Баллы
155
Article originally published here :

Пожалуйста Авторизируйтесь или Зарегистрируйтесь для просмотра скрытого текста.



This is a React disaster, because I can spend countless hour on this (well-known!), but simple bug :

"Each child in a list should have a unique 'key' prop."

Wait, wait, wait... I already googled around and it seems so easy to fix!

I had already set a unique key on every element in my list!

Who's in charge? Who's guilty?

Undefined data when initializing my component.

Yup.

Here's what was happening:

  1. My server component was loading data
  2. Before loading, my state was undefined
  3. My PlotMap was trying to map over undefined
  4. React threw the key error

The solution was simple but so easy to miss

Check my data before passing it to my component!

This simple conditional rendering fixed everything.

Always make sure your data exists before using it!


// This is wrong, causing an error
<PlotMap data={data}>

// Fixed!
{data && <PlotMap data={data}>}


Пожалуйста Авторизируйтесь или Зарегистрируйтесь для просмотра скрытого текста.

 
Вверх Снизу