Files

124 lines
2.8 KiB
Markdown
Raw Permalink Normal View History

---
id: 587d7fa7367417b2b2512bc7
title: Cambia estilos con base en los datos
challengeType: 6
forumTopicId: 301479
dashedName: change-styles-based-on-data
---
# --description--
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.
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:
```js
selection.style("color", (d) => {
2021-07-09 21:23:54 -07:00
});
```
El método `style()` no está limitado a configurar el `color` puede ser usado también con otras propiedades CSS.
# --instructions--
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.
**Nota:** Puedes usar lógica if-else, o el operador ternario.
# --hints--
El primer `h2` debe tener un `color` rojo.
```js
assert($('h2').eq(0).css('color') == 'rgb(255, 0, 0)');
```
El segundo `h2` debe tener un `color` verde.
```js
assert($('h2').eq(1).css('color') == 'rgb(0, 128, 0)');
```
El tercer `h2` debe tener un `color` verde.
```js
assert($('h2').eq(2).css('color') == 'rgb(0, 128, 0)');
```
El cuarto `h2` debe tener un `color` rojo.
```js
assert($('h2').eq(3).css('color') == 'rgb(255, 0, 0)');
```
El quinto `h2` debe tener un `color` verde.
```js
assert($('h2').eq(4).css('color') == 'rgb(0, 128, 0)');
```
El sexto `h2` debe tener un `color` rojo.
```js
assert($('h2').eq(5).css('color') == 'rgb(255, 0, 0)');
```
El séptimo `h2` debe tener un `color` verde.
```js
assert($('h2').eq(6).css('color') == 'rgb(0, 128, 0)');
```
El octavo `h2` debe tener un `color` rojo.
```js
assert($('h2').eq(7).css('color') == 'rgb(255, 0, 0)');
```
El noveno `h2` debe tener un `color` rojo.
```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>
```