3.7 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
587d7fa8367417b2b2512bca | Alterar a apresentação de um gráfico de barras | 6 | 301481 | change-the-presentation-of-a-bar-chart |
--description--
No último desafio, criamos um gráfico de barras, mas há algumas mudanças de formatação que poderiam melhorá-lo:
-
Adicione espaço entre cada barra para separá-las visualmente. Isso é feito adicionando uma margem ao CSS para a classe
bar
-
Aumente a altura das barras para mostrar melhor a diferença dos valores. Isso é feito multiplicando o valor por um número para dimensionar a altura
--instructions--
Primeiro, adicione uma margin
de 2px
à classe bar
na tag style
. Depois, altere a função de callback no método style()
para que retorne um valor 10
vezes maior que o valor original dos dados (e a expressão px
).
Observação: multiplicar cada ponto dos dados pela mesma constante somente altera a escala. É como fazer um zoom. Isso não altera o significado dos dados subjacentes.
--hints--
A primeira div
deve ter uma height
de 120
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(0).css('height') == '120px' &&
$('div').eq(0).css('margin-right') == '2px'
);
A segunda div
deve ter uma height
de 310
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(1).css('height') == '310px' &&
$('div').eq(1).css('margin-right') == '2px'
);
A terceira div
deve ter uma height
de 220
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(2).css('height') == '220px' &&
$('div').eq(2).css('margin-right') == '2px'
);
A quarta div
deve ter uma height
de 170
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(3).css('height') == '170px' &&
$('div').eq(3).css('margin-right') == '2px'
);
A quinta div
deve ter uma height
de 250
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(4).css('height') == '250px' &&
$('div').eq(4).css('margin-right') == '2px'
);
A sexta div
deve ter uma height
de 180
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(5).css('height') == '180px' &&
$('div').eq(5).css('margin-right') == '2px'
);
A sétima div
deve ter uma height
de 290
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(6).css('height') == '290px' &&
$('div').eq(6).css('margin-right') == '2px'
);
A oitava div
deve ter uma height
de 140
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(7).css('height') == '140px' &&
$('div').eq(7).css('margin-right') == '2px'
);
A nona div
deve ter uma height
de 90
pixels e uma margin
de 2
pixels.
assert(
$('div').eq(8).css('height') == '90px' &&
$('div').eq(8).css('margin-right') == '2px'
);
--seed--
--seed-contents--
<style>
.bar {
width: 25px;
height: 100px;
/* Add your code below this line */
/* Add your code above this line */
display: inline-block;
background-color: blue;
}
</style>
<body>
<script>
const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];
d3.select("body").selectAll("div")
.data(dataset)
.enter()
.append("div")
.attr("class", "bar")
.style("height", (d) => (d + "px")) // Change this line
</script>
</body>
--solutions--
<style>
.bar {
width: 25px;
height: 100px;
margin: 2px;
display: inline-block;
background-color: blue;
}
</style>
<body>
<script>
const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];
d3.select("body").selectAll("div")
.data(dataset)
.enter()
.append("div")
.attr("class", "bar")
.style("height", (d) => (d * 10 + "px"))
</script>
</body>