freeCodeCamp/curriculum/challenges/portuguese/04-data-visualization/data-visualization-with-d3/change-styles-based-on-data.md

3.0 KiB

id title challengeType forumTopicId dashedName
587d7fa7367417b2b2512bc7 Alterar estilos com base nos dados 6 301479 change-styles-based-on-data

--description--

O D3 tem a ver com a visualização e a apresentação dos dados. Você provavelmente vai querer alterar o estilo de elementos com base nos dados. Você pode usar uma função de callback no método style() para mudar a estilização para elementos diferentes.

Por exemplo, pode ser que você queira colorir um ponto dos dados em azul se ele tiver um valor inferior a 20, ou em vermelho se for igual ou superior. Você pode usar uma função de callback no método style() e incluir uma lógica condicional. A função de callback usa o parâmetro d para representar o ponto de dados:

selection.style("color", (d) => {

});

O método style() não é limitado a definir color - ele também pode ser usado com outras propriedades do CSS.

--instructions--

Adicione o método style() ao código no editor para definir color para os elementos h2 de modo condicional. Escreva a função de callback de modo que, se o valor do dado for inferior a 20, ela retornará "red" (vermelho). Do contrário, retornará "green" (verde).

Observação: você pode usar a lógica de if-else ou o operador ternário.

--hints--

O primeiro h2 deve ter color definido como "red".

assert($('h2').eq(0).css('color') == 'rgb(255, 0, 0)');

O segundo h2 deve ter color definido como "green".

assert($('h2').eq(1).css('color') == 'rgb(0, 128, 0)');

O terceiro h2 deve ter color definido como "green".

assert($('h2').eq(2).css('color') == 'rgb(0, 128, 0)');

O quarto h2 deve ter color definido como "red".

assert($('h2').eq(3).css('color') == 'rgb(255, 0, 0)');

O quinto h2 deve ter color definido como "green".

assert($('h2').eq(4).css('color') == 'rgb(0, 128, 0)');

O quinto h2 deve ter color definido como "red".

assert($('h2').eq(5).css('color') == 'rgb(255, 0, 0)');

O sétimo h2 deve ter color definido como "green".

assert($('h2').eq(6).css('color') == 'rgb(0, 128, 0)');

O oitavo h2 deve ter color definido como "red".

assert($('h2').eq(7).css('color') == 'rgb(255, 0, 0)');

O nono h2 deve ter color definido como "red".

assert($('h2').eq(8).css('color') == 'rgb(255, 0, 0)');

--seed--

--seed-contents--

<body>
  <script>
    const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];

    d3.select("body").selectAll("h2")
      .data(dataset)
      .enter()
      .append("h2")
      .text((d) => (d + " USD"))
      // Add your code below this line



      // Add your code above this line
  </script>
</body>

--solutions--

<body>
  <script>
    const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];

    d3.select("body").selectAll("h2")
      .data(dataset)
      .enter()
      .append("h2")
      .text((d) => (d + " USD"))
      .style("color", (d) => d < 20 ? "red" : "green")
  </script>
</body>