< Return to Video

Cambiando clases de CSS

  • 0:01 - 0:06
    En la guía paso a paso anterior, les mostré cómo establecer estilos en JavaScript, como éste.
  • 0:06 - 0:10
    Ahora, si estableces muchos estilos en JavaScript, podrías terminar
  • 0:10 - 0:15
    con cientos de líneas de código sólo para establecer valores de propiedades de CSS.
  • 0:15 - 0:18
    Y eso realmente podría estorbar tu JavaScript.
  • 0:18 - 0:21
    Hay otra manera de hacer esto.
  • 0:21 - 0:23
    Podemos crear una clase de CSS,
  • 0:23 - 0:28
    y añadir una regla de CSS para esa clase con los nuevos estilos que deseamos,
  • 0:28 - 0:33
    y luego dinámicamente añadir ese nombre de clase en JavaScript.
  • 0:33 - 0:39
    Vamos a probar esto empezando aquí en la etiqueta "".
  • 0:39 - 0:46
    Vamos a hacer una clase ".catcolors", y una regla para esta clase.
  • 0:46 - 0:53
    Y va a tener "color: orange;", y "background-color: black;".
  • 0:53 - 0:59
    Ahora, para asignar esto al elemento "heading", podemos decir:
  • 0:59 - 1:06
    'headingEl.className = "catcolors";'
  • 1:06 - 1:09
    Y podemos borrar la asignación de color
  • 1:09 - 1:12
    y de color de fondo en JavaScript.
  • 1:12 - 1:13
    ¡Tan tan!
  • 1:13 - 1:15
    Esto funciona.
  • 1:15 - 1:17
    Ahora, ¿notaron algo raro?
  • 1:17 - 1:21
    El atributo de HTML para nombres de clases es justamente "class".
  • 1:21 - 1:27
    Si hubiera hecho esto en HTML, esto sería 'class="catcolors"'.
  • 1:27 - 1:32
    Pero cuando lo hago en JavaScript, tengo que escribir ".className",
  • 1:32 - 1:34
    que no estamos acostumbrados a usar.
  • 1:34 - 1:39
    Y eso es porque "class" es en realidad un palabra clave en el lenguaje JavaScript
  • 1:39 - 1:43
    que tiene un significado especial para el lenguaje.
  • 1:43 - 1:48
    Así que por eso los navegadores usan "className" para referirse
  • 1:48 - 1:52
    al atributo "class" de HTML, sólo para asegurarse de no entrar en confusiones.
  • 1:52 - 1:57
    Así que recuerda, si quieres establecer el atributo clase para un elemento,
  • 1:57 - 2:00
    debes escribir: punto "className" igual (.className=).
  • 2:00 - 2:04
    Ahora para asignar eso a cada uno de los nombres de los animales,
  • 2:04 - 2:07
    podemos ponerlo dentro del ciclo, entonces:
  • 2:07 - 2:13
    'nameEls[i].className = "catcolors";'
  • 2:13 - 2:19
    Eso va a añadir el nombre de clase, pero en realidad va a quitar cualquier clase
  • 2:19 - 2:24
    que estuviera allí antes, porque lo hicimos "igual a".
  • 2:24 - 2:28
    Así que si teníamos ahí alguna clase antes, ahora ya no está.
  • 2:28 - 2:32
    Ahora, antes había clases, aquí tenemos 'class="animal"'.
  • 2:32 - 2:34
    Y ahora se han convertido en "catcolors".
  • 2:34 - 2:41
    Entonces lo que realmente queremos hacer es añadir un nuevo nombre de clase a este atributo de clase.
  • 2:41 - 2:48
    Y podemos hacer eso escribiendo "+= catcolors".
  • 2:48 - 2:49
    Muy bien.
  • 2:49 - 2:52
    Es seguro hacer esto, porque tomará la clase,
  • 2:52 - 2:58
    y a cualquier cosa que tenía antes le va a añadir un espacio y va a añadir la nueva clase.
  • 2:58 - 3:02
    Hay otra manera de hacer esto en los navegadores nuevos,
  • 3:02 - 3:05
    usando la propiedad "classList".
  • 3:05 - 3:16
    Para hacer esto escribimos:
    'nameEls[i].classList.add("catcolors");'.
  • 3:16 - 3:20
    Ahora, eso es mejor, pero no funciona en todos lados.
  • 3:20 - 3:24
    Así que si quieres usar eso, tienes que ir a "caniuse.com",
  • 3:24 - 3:27
    y asegurarte de que funcione en todos los navegadores
  • 3:27 - 3:29
    en los que quieres que funcione tu página web.
  • 3:29 - 3:32
    Es mucho más bonito, pero no es agradable que tu página web falle
  • 3:32 - 3:36
    porque estás usando una función que el navegador no puede soportar.
  • 3:36 - 3:38
    Así que yo lo voy a comentar,
  • 3:38 - 3:41
    porque quiero que mi página funcione en muchos navegadores.
  • 3:41 - 3:46
    Hay muchas veces en las que queremos cambiar estilos individuales,
  • 3:46 - 3:49
    en lugar de asignarles nombres de clases.
  • 3:49 - 3:54
    Así que una vez más, sólo recuerda que tienes ambas herramientas en tu caja de herramientas,
  • 3:54 - 3:59
    y piensa cuál será mejor usar, dependiendo de la situación.
Title:
Cambiando clases de CSS
Description:

more » « less
Video Language:
English
Duration:
04:00
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Changing CSS classes
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Changing CSS classes
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Changing CSS classes
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Changing CSS classes
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Changing CSS classes
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Changing CSS classes
Martha Isabel Soriano Ruiz edited Spanish, Mexican subtitles for Changing CSS classes

Spanish, Mexican subtitles

Revisions