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

0

144
Views
<li> elementos a los que les faltan claves asignadas después de iterar a través de la variable de matriz de estado (ReactJS)

Tengo problemas para averiguar por qué mis elementos li no tienen sus claves asignadas en el DOM. Sigo recibiendo el error " Advertencia: cada niño en una lista debe tener un accesorio de 'clave' único " incluso después de proporcionar una clave única.

¡Tengan paciencia conmigo porque todavía estoy aprendiendo! Esto es usando ReactJS.

Este es el componente que usa publicaciones (una variable de estado con una matriz de objetos) y lo itera, devolviendo el componente Publicar cada vez, usando .map(). Cada objeto dentro de la matriz de estado tiene una propiedad de contenido y tipo .

Paso el índice como accesorio:

 import React from "react"; import Post from "./Post"; function PostList({ posts, handleDelete }) { const postsLi = posts.map((post, index) => { return ( <Post post={post} postIndex={index} handleDelete={handleDelete} /> ) }) return ( <div className="post-list"> <ul> {postsLi} </ul> </div> ); } export default PostList;

Aquí está el componente Publicar:

 import React, { useState } from "react"; function Post({ post, postIndex, handleDelete }) { const { content, type } = post; const textContent = (<p key={`a${postIndex}`}>{content}</p>); const urlContent = (<img key={`i${postIndex}`} src={content} />) const finalContent = type === "textarea" ? textContent : urlContent; //Need to figure out why key attribute isn't showing up return ( <li key={`post-${postIndex}`} className="post" > {finalContent} <br /> <button key={`b${postIndex}`} name="delete" onClick={handleDelete} id={postIndex}>Delete</button> </li> ) } export default Post;

Leí en otra publicación que todos los niños dentro de un elemento li también deben tener claves, pero eso tampoco funcionó. Post no se considera hermano de PostList, ¿verdad? Además, el elemento del botón tiene correctamente un valor de identificación del índice, por lo que se pasa al componente Publicar sin problemas.

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

0

Leí en otra publicación que todos los niños dentro de un elemento li también necesitan tener claves, pero eso tampoco funcionó.

Tal vez hayas leído este artículo: https://sentry.io/answers/unique-key-prop/

Al crear una lista en la interfaz de usuario a partir de una matriz con JSX, debe agregar una propiedad clave para cada elemento secundario y para cualquiera de sus elementos secundarios.

Ej: <li key="uniqueId1" >Item1</li>

React usa la propiedad clave para crear una relación entre el componente y el elemento DOM. La biblioteca utiliza esta relación para determinar si el componente debe volver a renderizarse o no.

No se recomienda utilizar el índice de la matriz como elemento clave si sabe que la matriz no será estática. Si la clave es un índice, el reordenamiento de un elemento en la matriz lo cambia. Entonces React se confundirá y volverá a renderizar el elemento incorrecto.

Las claves no tienen que ser únicas globalmente. Solo necesitan ser únicos entre los elementos hermanos.

En su caso, desea usar el índice como clave key={index} en su elemento Publicar, no está seguro si su matriz no será estática (como se mencionó anteriormente).

 const postsLi = posts.map((post, index) => { return ( <Post key={key} post={post} postIndex={index} handleDelete={handleDelete} /> ) })
almost 3 years ago · Juan Pablo Isaza Report

0

Agregue una clave a esta declaración y creo que solucionaría ese error:

 const postsLi = posts.map((post, index) => { return ( <Post key={"some unique key" or index} post={post} postIndex={index} handleDelete={handleDelete} /> ) })
almost 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