--- id: 5a24c314108439a4d403616a title: Pasa un arreglo como "props" challengeType: 6 forumTopicId: 301401 dashedName: pass-an-array-as-props --- # --description-- El último desafío demostró cómo pasar información desde un componente padre a un componente hijo como `props` o propiedades. Este desafío busca demostrar cómo se pueden pasar arreglos como `props`. Para pasar un arreglo a un elemento JSX, debe ser tratado como JavaScript y envolverlo entre llaves. ```jsx ``` El componente hijo entonces tiene acceso a la propiedad del arreglo `colors`. Los métodos de arreglo, como `join()` pueden ser usados al acceder a la propiedad. `const ChildComponent = (props) =>

{props.colors.join(', ')}

` Esto unirá a todos elementos `colors` del arreglo en una cadena separada por comas y se convertirá en: `

green, blue, red

` Más tarde, aprenderemos sobre otros métodos comunes para representar arreglos de datos en React. # --instructions-- Están los componentes `List` y `ToDo` en el editor de código. Al renderizar cada `List` del componente `ToDo`, pasa una propiedad `tasks` asignada a un arreglo de tareas pendientes, por ejemplo `["walk dog", "workout"]`. Luego, accede a este arreglo de `tasks` en el componente `List`, mostrando su valor dentro del elemento `p`. Usa `join(", ")` para mostrar el arreglo `props.tasks` en el elemento `p` como una lista separada por comas. La lista de hoy debe tener al menos 2 tareas y la de mañana debe tener al menos 3 tareas. # --hints-- El componente `ToDo` debe devolver un solo elemento `div`. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.children().first().type() === 'div'; })() ); ``` El tercer hijo del componente `ToDo` debe ser una instancia del componente `List`. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.children().first().childAt(2).name() === 'List'; })() ); ``` El quinto hijo del componente `ToDo` debe ser una instancia del componente `List`. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.children().first().childAt(4).name() === 'List'; })() ); ``` Ambas instancias del componente `List` deben tener una propiedad llamada `tasks` y `tasks` debe ser de tipo arreglo. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return ( Array.isArray(mockedComponent.find('List').get(0).props.tasks) && Array.isArray(mockedComponent.find('List').get(1).props.tasks) ); })() ); ``` El primer componente `List` que representa las tareas de hoy debe tener 2 o más elementos. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.find('List').get(0).props.tasks.length >= 2; })() ); ``` El segundo componente `List` que representa las tareas para mañana debe tener 3 o más elementos. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.find('List').get(1).props.tasks.length >= 3; })() ); ``` El componente `List` debe renderizar el valor del prop `tasks` en la etiqueta `p`. ```js assert( (function () { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return ( mockedComponent .find('p') .get(0) .props.children.replace(/\s*,\s*/g, ',') === mockedComponent .find('List') .get(0) .props.tasks.join(',') .replace(/\s*,\s*/g, ',') && mockedComponent .find('p') .get(1) .props.children.replace(/\s*,\s*/g, ',') === mockedComponent .find('List') .get(1) .props.tasks.join(',') .replace(/\s*,\s*/g, ',') ); })() ); ``` # --seed-- ## --after-user-code-- ```jsx ReactDOM.render(, document.getElementById('root')) ``` ## --seed-contents-- ```jsx const List = (props) => { { /* Change code below this line */ } return

{}

{ /* Change code above this line */ } }; class ToDo extends React.Component { constructor(props) { super(props); } render() { return (

To Do Lists

Today

{ /* Change code below this line */ }

Tomorrow

{ /* Change code above this line */ }
); } }; ``` # --solutions-- ```jsx const List= (props) => { return

{props.tasks.join(', ')}

}; class ToDo extends React.Component { constructor(props) { super(props); } render() { return (

To Do Lists

Today

Tomorrow

); } }; ```