• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

508
Views
Cada niño en una lista debe tener un accesorio de "clave" único. Lo hice, pero todavía veo este error

Conozco el accesorio clave, así que lo hice en el componente listitem

 const ListItem = ({item}) => { const {result, time, id} = item; return( <li key={id} className='list__item'> <span className='item__result'>{result} cps</span> <span className='item__date'>{time}</span> <button className='item__delete'>delete</button> </li> )}

Y aquí está el componente, donde lo uso.

 const Leadboard = () => { const [data, setData] = useState([{result:'5,63', time:'08.06.2022', id: (new Date()).toString(16)}, {result:'5,63', time:'08.06.2022', id: +(new Date() - 1)}, {result:'5,63', time:'08.06.2022', id: +(new Date() - 2)}]); let elements=data.map(item => { return ( <> <ListItem item={item} /> </> ) }); return( <div className='app-leadboard'> <span className='app-leadboard__title'>Your's best results:</span> <ol className='app-leadboard__list' type='1'> {elements} </ol> </div> )}

Pero después de renderizar sigo viendo el error "accesorio clave"

Pasé mucho tiempo en esto, pero no puedo entender qué está mal. Así que smb, ayuda por favor con eso

about 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

Tienes la lista equivocada. Son los componentes <ListItem> los que necesitan la clave. (Y puedes deshacerte de los fragmentos de reacción a su alrededor porque no tienen sentido).

about 3 years ago · Juan Pablo Isaza Report

0

React primero accede al corchete vacío ( <> </> ) antes de acceder al atributo key en su componente secundario.

Así que necesitas

  1. Utilice los corchetes vacíos y pásele el atributo key .
 // Use React.Fragment let elements=data.map(item => { return ( <React.Fragment key={item.id}> <ListItem item={item} /> </React.Fragment> ) });

y elimine la clave en el componente secundario ( ListItem )

 ListItem.js <li /* Remove this key={id} */ className='list__item'>

O

Deshágase de los corchetes vacíos ( <> </> ) y haga referencia directamente al componente secundario.

 let elements=data.map(item => { return (<ListItem item={item} />) });

y deje el atributo key en el componente secundario

Más sobre Reaccionar Fragmento. Documentos oficiales de React

about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error