freeCodeCamp/curriculum/challenges/portuguese/03-front-end-libraries/react/pass-an-array-as-props.port...

5.9 KiB
Raw Blame History

id title challengeType isRequired videoUrl localeTitle
5a24c314108439a4d403616a Pass an Array as Props 6 false Passar uma matriz como adereços

Description

O último desafio demonstrou como passar informações de um componente pai para um componente filho como props ou propriedades. Este desafio analisa como as matrizes podem ser passadas como props . Para passar uma matriz para um elemento JSX, ela deve ser tratada como JavaScript e envolvida em chaves.
<ParentComponent>
<Cores do ChildComponent = {["green", "blue", "red"]} />
</ ParentComponent>
O componente filho, em seguida, tem acesso às colors propriedade de matriz. Métodos de matriz como join() podem ser usados ao acessar a propriedade. const ChildComponent = (props) => <p>{props.colors.join(', ')}</p> Isso unirá todos os itens da matriz de colors em uma string separada por vírgula e produzirá: <p>green, blue, red</p> Mais tarde, aprenderemos sobre outros métodos comuns para renderizar matrizes de dados no React.

Instructions

Existem componentes List e ToDo no editor de código. Ao renderizar cada List do componente ToDo , passe uma propriedade de tasks atribuída a uma matriz de tarefas, por exemplo ["walk dog", "workout"] . Em seguida, acesse essa matriz de tasks no componente List , mostrando seu valor dentro do elemento p . Use join(", ") para exibir a matriz props.tasks no elemento p como uma lista separada por vírgulas. A lista de hoje deve ter pelo menos duas tarefas e a de amanhã deve ter pelo menos três tarefas.

Tests

tests:
  - text: O componente <code>ToDo</code> deve retornar um único <code>div</code> externo.
    testString: 'assert((function() { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.children().first().type() === "div"; })(), "The <code>ToDo</code> component should return a single outer <code>div</code>.");'
  - text: O terceiro filho do componente <code>ToDo</code> deve ser uma instância do componente <code>List</code> .
    testString: 'assert((function() { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.children().first().childAt(2).name() === "List"; })(), "The third child of the <code>ToDo</code> component should be an instance of the <code>List</code> component.");'
  - text: O quinto filho do componente <code>ToDo</code> deve ser uma instância do componente <code>List</code> .
    testString: 'assert((function() { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.children().first().childAt(4).name() === "List"; })(), "The fifth child of the <code>ToDo</code> component should be an instance of the <code>List</code> component.");'
  - text: Ambas as instâncias do componente <code>List</code> devem ter uma propriedade chamada <code>tasks</code> e <code>tasks</code> devem ser do tipo array.
    testString: '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); })(), "Both instances of the <code>List</code> component should have a property called <code>tasks</code> and <code>tasks</code> should be of type array.");'
  - text: O primeiro componente <code>List</code> que representa as tarefas para hoje deve ter dois ou mais itens.
    testString: 'assert((function() { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.find("List").get(0).props.tasks.length >= 2; })(), "The first <code>List</code> component representing the tasks for today should have 2 or more items.");'
  - text: O segundo componente <code>List</code> que representa as tarefas de amanhã deve ter 3 ou mais itens.
    testString: 'assert((function() { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.find("List").get(1).props.tasks.length >= 3; })(), "The second <code>List</code> component representing the tasks for tomorrow should have 3 or more items.");'
  - text: 'O componente <code>List</code> deve renderizar o valor das <code>tasks</code> prop da tag <code>p</code> como uma lista separada por vírgulas, por exemplo <code>walk dog, workout</code> .'
    testString: 'assert((function() { const mockedComponent = Enzyme.mount(React.createElement(ToDo)); return mockedComponent.find("p").get(0).props.children === mockedComponent.find("List").get(0).props.tasks.join(", ") && mockedComponent.find("p").get(1).props.children === mockedComponent.find("List").get(1).props.tasks.join(", "); })(), "The <code>List</code> component should render the value from the <code>tasks</code> prop in the <code>p</code> tag as a comma separated list, for example <code>walk dog, workout</code>.");'

Challenge Seed

const List= (props) => {
  { /* change code below this line */ }
  return <p>{}</p>
  { /* change code above this line */ }
};

class ToDo extends React.Component {
  constructor(props) {
    super(props);
  }
  render() {
    return (
      <div>
        <h1>To Do Lists</h1>
        <h2>Today</h2>
        { /* change code below this line */ }
        <List/>
        <h2>Tomorrow</h2>
        <List/>
        { /* change code above this line */ }
      </div>
    );
  }
};

After Test

console.info('after the test');

Solution

// solution required