Crear una lista en el navegador es una técnica muy común para mostrar una lista de datos. En este tutorial, aprenderemos cómo crear una lista de elementos usando React. Es un poco diferente de cómo podría abordar esto cuando usa algunos de los otros marcos de interfaz de usuario populares como Vue o Angular. En esos otros marcos, tiene directivas personalizadas como v-for o ng-for para iterar directamente en html. Con react, el enfoque es utilizar JavaScript nativo para la iteración. Entonces, en React, puede usar la función map () para iterar sobre una matriz y crear una lista. Veamos cómo hacerlo ahora.
Crear una lista estática
Ok, lo primero es lo primero. Antes incluso de usar cualquier arreglo de JavaScript para ayudar a crear una lista, recordemos cómo simplemente representar una lista estática. Entonces, con este marcado, deberíamos estar en el negocio.
Representar una lista de forma dinámica
Para representar una lista dinámicamente en React, comenzamos agregando una propiedad al objeto de estado. Podemos poblar esa propiedad con una matriz de cadenas como esta.
Excelente. Ahora queremos pasar al método render () para representar cada elemento de la lista de forma dinámica. Aquí es donde, en otros marcos, buscaría directivas de tipo ng-for o v-for. No podemos hacer eso en React. En su lugar, buscamos la función de mapa incorporada en JavaScript. Podemos usar la función de mapa para asignar cada elemento de la matriz a un elemento de reacción. Observe que pasamos una función de flecha como argumento a la función de mapa.
En este punto tenemos una lista, pero cada li está vacío.
¿Cómo podemos arreglar eso? Todo lo que tenemos que hacer es usar las llaves en la expresión JSX para generar cada elemento de la lista como tal.
¡Aquí vamos! Tenemos nuestra lista renderizada dinámicamente usando React junto con la función de mapa de JavaScript.
Solo para demostrar que la lista es dinámica, podemos cambiar los datos en la matriz listitems y ver qué sucede.
Cada niño en una lista debe tener un accesorio "clave" único
Ahora tenemos una lista que se muestra bien, pero no hemos terminado. Al inspeccionar la consola en el navegador, ahora notamos un mensaje de advertencia en texto rojo.
index.js: 1446 Advertencia: Cada niño en una lista debe tener un accesorio de "clave" único.
Compruebe el método de renderizado de
Item
. Consulte https://fb.me/react-warning-keys para obtener más información.
¿Que está sucediendo aquí? La razón por la que React se queja de esto es porque necesita identificar de forma única cada elemento de nuestra lista. Si el estado de este elemento de reacción en el dom virtual cambia, React necesita averiguar rápidamente qué elemento cambió y en qué lugar del dom real necesita reflejar ese cambio. Entonces, ¿cómo arreglamos esto? Bueno, cada vez que usamos la función de mapa para representar una lista de elementos, necesitamos establecer el atributo clave en el li de la lista. Así es como se hace.
Entonces, en la línea resaltada arriba, observe que ahora hemos agregado un conjunto de claves a un valor dinámico en el elemento li. Ahora, en este caso, cada listitem es una cadena y cada cadena es única. Por lo tanto, podemos usar listitem como el valor de key. Una vez más, inspeccionamos la consola de herramientas del desarrollador y ya no obtenemos el error de Cada niño en una lista debería tener un accesorio "clave" único . En otros escenarios, la matriz con la que está tratando podría contener objetos. En ese caso, cada objeto podría tener una identificación única, y ese sería el valor del atributo clave. Además, esta clave única es única por lista representada, no para toda la aplicación.
Representar una matriz de objetos como una lista
Para terminar, rendericemos una lista donde la propiedad del estado contiene una matriz de objetos. De esa manera, podemos ver cómo funciona el enfoque de clave única cuando se utilizan objetos en lugar de cadenas simples.
]
Representación de una lista con resumen de React
Como hemos visto, renderizar una lista en React no es tan malo. Si bien React no tiene el azúcar sintáctico de ng-for o v-for, podemos simplemente usar la función de mapa de JavaScript para producir el mismo efecto. Ese parece ser un tema común en React: usar JavaScript nativo para realizar ciertas tareas mientras deja que React administre el dom virtual.
0 Comentarios