Ошибка ESLint: каждый дочерний элемент в списке должен иметь уникальный ключ - PullRequest
0 голосов
/ 26 апреля 2020

У меня есть строка JSON, как показано ниже. Строка имеет \ n для следующей строки.

data:{a:"A computer is a machine that can be instructed to carry out sequences of arithmetic or logical operations automatically via computer programming. Modern computers have the ability to follow generalized sets of operations, called programs. These programs enable computers to perform an extremely wide range of tasks. A "complete" computer including the hardware, the operating system (main software), and peripheral equipment required and used for "full" operation can be referred to as a computer system. This term may as well be used for a group of computers that are connected and work together, in particular, a computer network or computer cluster.\nComputers are used as control systems for a wide variety of industrial and consumer devices. This includes simple special purpose devices like microwave ovens and remote controls, factory devices such as industrial robots and computer-aided design, and also general-purpose devices like personal computers and mobile devices such as smartphones. The Internet is run on computers and it connects hundreds of millions of other computers and their users."}

Я использовал ее в React, как показано ниже:

const b = data.a.split("\n");
return(
<P>
b.map((p,index)=>({p}<br key={index}/>))
</p>

Я получил предупреждение ES lint Для приведенного выше кода. Предупреждение как показано ниже.

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

Как можно избежать предупреждения? Мне нужен текст в теге абзаца, и каждая строка разрывается в тексте (\n) и заменяется на <br/>

Ответы [ 2 ]

2 голосов
/ 26 апреля 2020
b.map((p,index)=>(<p key={index}>{p}</p>))

Вам нужен ключ на элементе обтекания. Просто используйте тег p, и вы получите разрыв строки бесплатно. ;)

Есть причины, по которым использование индекса в качестве ключа является плохой идеей .

0 голосов
/ 26 апреля 2020

Вам необходимо установить атрибут key для элемента, возвращаемого из map вместо <br> элемента.

Попробуйте что-то вроде этого:

<P>
  { React.Children.toArray(b.map((p,index)=>({p}<br/>))) }
</p>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...