2021-02-06 04:42:36 +00:00
---
id: 587d7fa7367417b2b2512bc7
2021-10-04 07:27:38 -07:00
title: Cambia estilos con base en los datos
2021-02-06 04:42:36 +00:00
challengeType: 6
forumTopicId: 301479
dashedName: change-styles-based-on-data
---
# --description--
2021-10-04 07:27:38 -07:00
D3 se trata de la visualización y presentación de datos. Probablemente vayas a querer estilizar los elementos con base en los datos. Puedes usar una función callback en el método `style()` para cambiar el estilo a diferentes elementos.
2021-02-06 04:42:36 +00:00
2021-10-04 07:27:38 -07:00
Por ejemplo, podrías querer colorear un punto de dato a azul si tiene un valor menor a 20, y a rojo en caso contrario. Puedes usar una función callback en el método `style()` e incluir la lógica condicional. La función callback usa el parámetro `d` para representar el punto de dato:
2021-02-06 04:42:36 +00:00
```js
selection.style("color", (d) => {
2021-07-09 21:23:54 -07:00
2021-02-06 04:42:36 +00:00
});
```
2021-10-04 07:27:38 -07:00
El método `style()` no está limitado a configurar el `color` puede ser usado también con otras propiedades CSS.
2021-02-06 04:42:36 +00:00
# --instructions--
2021-10-04 07:27:38 -07:00
Agrega el método `style()` al código en el editor para establecer el `color` de los elementos `h2` de manera condicional. Escribe la función callback para que si el valor del dato es menor a 20, retorne rojo, de lo contrario, retorna verde.
2021-02-06 04:42:36 +00:00
2021-10-04 07:27:38 -07:00
**Nota:** Puedes usar lógica if-else, o el operador ternario.
2021-02-06 04:42:36 +00:00
# --hints--
2021-10-04 07:27:38 -07:00
El primer `h2` debe tener un `color` rojo.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(0).css('color') == 'rgb(255, 0, 0)');
```
2021-10-04 07:27:38 -07:00
El segundo `h2` debe tener un `color` verde.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(1).css('color') == 'rgb(0, 128, 0)');
```
2021-10-04 07:27:38 -07:00
El tercer `h2` debe tener un `color` verde.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(2).css('color') == 'rgb(0, 128, 0)');
```
2021-10-04 07:27:38 -07:00
El cuarto `h2` debe tener un `color` rojo.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(3).css('color') == 'rgb(255, 0, 0)');
```
2021-10-04 07:27:38 -07:00
El quinto `h2` debe tener un `color` verde.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(4).css('color') == 'rgb(0, 128, 0)');
```
2021-10-04 07:27:38 -07:00
El sexto `h2` debe tener un `color` rojo.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(5).css('color') == 'rgb(255, 0, 0)');
```
2021-10-04 07:27:38 -07:00
El séptimo `h2` debe tener un `color` verde.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(6).css('color') == 'rgb(0, 128, 0)');
```
2021-10-04 07:27:38 -07:00
El octavo `h2` debe tener un `color` rojo.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(7).css('color') == 'rgb(255, 0, 0)');
```
2021-10-04 07:27:38 -07:00
El noveno `h2` debe tener un `color` rojo.
2021-02-06 04:42:36 +00:00
```js
assert($('h2').eq(8).css('color') == 'rgb(255, 0, 0)');
```
# --seed--
## --seed-contents--
```html
< 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--
```html
< 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 >
```