Files

2.1 KiB

id, title, challengeType, forumTopicId, dashedName
id title challengeType forumTopicId dashedName
587d7fa7367417b2b2512bc8 Agrega clases con D3 6 301473 add-classes-with-d3

--description--

Usar muchos estilos en línea en elementos HTML se vuelve difícil de administrar, incluso para aplicaciones más pequeñas. Es más fácil agregar una clase a los elementos y darle estilo a esa clase una vez usando las reglas CSS. D3 tiene el método attr() para agregar cualquier atributo HTML a un elemento, incluido un nombre de clase.

El método attr() funciona de la misma manera que style(). Toma valores separados por comas y puede usar una función callback. A continuación, se muestra un ejemplo para agregar una clase de container a una selección:

selection.attr("class", "container");

Ten en cuenta que el parámetro class seguirá siendo el mismo siempre que necesites agregar una clase y solo cambiará el parámetro container.

--instructions--

Agrega el método attr() al código en el editor y coloca una clase de bar en los elementos div.

--hints--

Tus elementos div deben tener una clase de bar.

assert($('div').attr('class').trim().split(/\s+/g).includes('bar'));

Tu código debe usar el método attr().

assert(code.match(/\.attr/g));

--seed--

--seed-contents--

<style>
  .bar {
    width: 25px;
    height: 100px;
    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")
      // Add your code below this line



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

--solutions--

<style>
  .bar {
    width: 25px;
    height: 100px;
    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")
      // Add your code below this line
      .attr("class","bar");
      // Add your code above this line
  </script>
</body>