Pseudoclases y pseudoelementos
El conjunto de selectores que estudiaremos en este artículo se conocen como pseudoclases y pseudoelementos. Hay muchos y a menudo sirven para fines muy específicos. Una vez que sepas cómo usarlos, puedes echar un vistazo a la lista para ver si alguno sirve para la página que quieres crear. Una vez más, la página correspondiente de MDN resulta muy útil para conocer qué navegadores los admiten o no.
Prerrequisitos: | Conocimientos básicos de informática, tener el software básico instalado, conocimientos básicos de trabajar con archivos, HTML básico (véase Introducción a HTML) y nociones de cómo funciona el CSS (véase Primeros pasos con el CSS). |
---|---|
Objetivo: | Obtener información sobre los selectores de pseudoclases y pseudoelementos. |
¿Qué es una pseudoclase?
Una pseudoclase es un selector que marca los elementos que están en un estado específico, por ejemplo, los que son el primer elemento de su tipo, o aquellos por los que el cursor les pasa por encima. Tienden a actuar como si hubieras aplicado una clase en una parte determinada del documento y, a menudo, ayudan a reducir el exceso de clases y proporcionan un marcado más flexible y fácil de mantener.
Las pseudoclases son palabras clave que comienzan con dos puntos:
:pseudo-class-name
Ejemplos simples de pseudoclases
Echemos un vistazo a algunos ejemplos. Si queremos el primer párrafo de un artículo en letra más grande y en negrita, podemos añadir una clase a ese párrafo y luego añadirle CSS a esa clase, como se muestra en este ejemplo:
Sin embargo, podría ser complicado de mantener. ¿Y si añadiésemos un párrafo nuevo en la parte superior del documento? Habría que mover la clase para que quede antes del nuevo párrafo. En lugar de añadir la clase, podríamos utilizar el selector de pseudoclase :first-child
, que siempre seleccionará el primer elemento hijo del artículo, y de esta forma no tendremos que editar el código HTML (esto no siempre es posible, tal vez debido a que lo genera un CMS).
Todas las pseudoclases se comportan del mismo modo. Seleccionan un fragmento del documento que está en un estado determinado y se comportan como si se hubiera añadido una clase a su HTML. Echa un vistazo a otros ejemplos en MDN:
Nota:
Es válido escribir pseudoclases y pseudoelementos sin que les preceda un selector de elemento. En el ejemplo anterior, podría escribirse :first-child
y la regla se aplicaríaa cualquier elemento que sea el primer hijo de un elemento <article>
, no solo un párrafo primer hijo. :first-child
equivale a *:first-child
. Pero normalmente se quiere más control y hay que ser más específico.
Pseudoclases de acción de usuario
Algunas pseudoclases solo intervienen cuando el usuario interactúa con el documento de alguna manera. Estas pseudoclases de acción de usuario, que también reciben el nombre de pseudoclases dinámicas, actúan como si se añadiese una clase al elemento cuando el usuario interactúa con él. Algunos ejemplos son:
¿Qué es un pseudoelemento?
Los pseudoelementos se comportan de manera similar. Sin embargo, actúan como si hubieras añadido un elemento HTML totalmente nuevo en el marcado, en lugar de haber aplicado una clase nueva a los elementos presentes. Los pseudoelementos empiezan con un doble signo de dos puntos ::
.
::pseudo-element-name
Nota: Algunos de los primeros pseudoelementos utilizaban la sintaxis de un solo signo de dos puntos, así que puede ser que en ocasiones los veas escritos de esta forma en algún código o ejemplo. Los navegadores modernos leen tanto los pseudoelementos con la sintaxis de los dos puntos simple como la de los dos puntos doble para garantizar la compatibilidad retrospectiva.
Por ejemplo, si deseas seleccionar la primera línea de un párrafo simplemente puedes delimitarlo con el elemento <span>
y utilizar un selector de elementos. Sin embargo, fallará si el número de palabras que has delimitado resulta ser más largo o más corto que el ancho del elemento padre. Ya que normalmente no sabemos cuántas palabras caben en una línea porque esto cambia con el ancho de la pantalla o con los cambios de tamaño de la letra, no es posible hacer esto introduciendo solo HTML.
El pseudoelemento ::first-line
soluciona este problema: no importa si el número de palabras aumenta o disminuye, siempre se selecciona la primera línea.
Actúa como si hubiera un elemento <span>
mágicamente delimitando esa primera línea, que se actualiza cada vez que la longitud de la línea cambia.
Puedes observar que en ambos párrafos se selecciona la primera línea.
Combinar pseudoclases y pseudoelementos
Si quieres poner en negrita la primera línea del primer párrafo, puedes encadenar los selectores :first-child
y ::first-line
. Añade al ejemplo anterior el CSS siguiente. Queremos que se seleccione la primera línea del primer elemento <p>
que esté dentro de un elemento <article>
.
article p:first-child::first-line {
font-size: 120%;
font-weight: bold;
}
Generar contenido con ::before y ::after
Hay un par de pseudoelementos especiales que se utilizan junto con la propiedad de content
para introducir contenido en el documento usando el CSS.
Puedes utilizarlos para insertar una cadena de texto, como en el ejemplo siguiente. Intenta cambiar el valor del texto de la propiedad content
y observa el cambio en la salida. También puedes cambiar el pseudoelemento ::before
por ::after
y verás que el texto se inserta al final del elemento, en lugar de al principio.
Sin embargo, en realidad no es habitual insertar cadenas de texto desde el CSS, porque ese texto resulta inaccesible para algunos lectores de pantalla y puede ser difícil de buscar y modificar en el futuro.
Un uso más adecuado de estos pseudoelementos es insertar un icono. Por ejemplo, la pequeña flecha que añadimos en el ejemplo siguiente es un indicador visual que no queremos que el lector de pantalla muestre:
Estos pseudoelementos también se utilizan con frecuencia para insertar una cadena vacía a la que luego se le puede aplicar estilo, como a cualquier otro elemento de la página.
En el ejemplo siguiente hemos añadido una cadena vacía mediante el pseudoelemento ::before
. Le hemos asociado display: block
para poder aplicarle estilo para que tenga una anchura y una altura determinadas. A continuación, utilizamos el CSS para aplicar estilo de la misma forma que lo haríamos con cualquier otro elemento. Juega con el CSS y cambia la forma en que se ve y se comporta.
El uso de los pseudoelementos ::before
y ::after
, junto con la propiedad content
se conoce como «contenido generado» en CSS, y verás que esta técnica se utiliza a menudo para diversas tareas. Un buen ejemplo es la página web CSS Arrow Please, que te ayuda a generar una flecha con CSS. Echa un vistazo al CSS a medida que creas tu flecha y verás cómo funcionan los pseudoelementos ::before
y ::after
. Cada vez que veas estos selectores, echa un vistazo a la propiedad content
para ver qué se añade al documento.
Sección de referencia
Hay un gran número de pseudoclases y pseudoelementos, así que resulta útil tener una lista para ir consultándolos. A continuación encontrarás un par de tablas con enlaces a sus páginas de referencia en MDN. Tómalas como referencia para ver de qué dispones para seleccionar qué tipos de elementos.
Las pseudoclases
Selector | Descripción |
---|---|
:active |
Selecciona un elemento cuando el usuario lo activa (por ejemplo, con un clic). |
:any-link |
Selecciona los estados :link y :visited de un enlace. |
:blank |
Selecciona un elemento <input> cuyo valor de entrada está vacío. |
:checked |
Selecciona un botón de opción o casilla de verificación en el estado que determines. |
:current |
Selecciona el elemento que se muestra en ese momento, o un ancestro de ese elemento. |
:default |
Selecciona uno o más elementos de interfaz de usuario cuyo valor es el predeterminado de entre un conjunto de elementos similares. |
:dir |
Selecciona un elemento según su direccionalidad (valor del atributo dir de HTML o propiedad direction de CSS). |
:disabled |
Selecciona elementos de la interfaz de usuario que están en estado inactivo. |
:empty |
Selecciona un elemento que no tiene elementos hijo, excepto por algún espacio en blanco opcional. |
:enabled |
Selecciona elementos de la interfaz de usuario que están en estado activo. |
:first |
En Paged Media, selecciona la primera página. |
:first-child |
Selecciona el primero entre elementos hermanos. |
:first-of-type |
Selecciona el primero entre un tipo determinado de elementos hermanos. |
:focus |
Selecciona el elemento que tiene el foco. |
:focus-visible |
Selecciona el elemento que tiene el foco cuando el foco tiene que estar visible para el usuario. |
:focus-within |
Selecciona el elemento que tiene el foco y el elemento con un descendiente que tiene el foco. |
:future |
Selecciona los elementos que van después del elemento en curso. |
:hover |
Selecciona un elemento cuando el usuario interactúa con él. |
:indeterminate |
Selecciona elementos de interfaz de usuario cuyo valor está en un estado no determinado, por lo general se trata de casillas de verificación. |
:in-range |
Selecciona un elemento cuyo valor se encuentra dentro de un rango de valores determinado. |
:invalid |
Selecciona un elemento, como por ejemplo un <input> , cuyo estado es no válido. |
:lang |
Selecciona un elemento según el idioma (valor del atributo lang de HTML). |
:last-child |
Selecciona el último elemento de entre sus elementos hermanos. |
:last-of-type |
Selecciona el último de entre los elementos hermanos de un tipo determinado. |
:left |
En Paged Media selecciona las páginas de la izquierda. |
:link |
Selecciona los enlaces no visitados. |
:local-link |
Selecciona los enlaces que dirigen a páginas que se encuentran en la misma página web que el documento activo. |
:is() |
Selecciona cualquiera de los selectores de la lista de selección que se pase como valor de este selector. |
:not |
Selecciona elementos que otros selectores no han seleccionado antes y que se han pasado como valor de este selector. |
:nth-child |
Selecciona elementos de entre una lista de elementos hermanos. Los elementos hermanos están relacionados por una fórmula del tipo an + b (por ejemplo, 2n + 1 seleccionaría los elementos 1, 3, 5, 7, etc., es decir, todos los impares). |
:nth-of-type |
Selecciona elementos de entre una lista de elementos hermanos de un tipo determinado (por ejemplo, todos los elementos <p> ). Los elementos hermanos están relacionados por una fórmula del tipo an + b (por ejemplo, 2n + 1 relacionaría en la secuencia ese tipo de elementos, los números 1, 3, 5, 7, etc., es decir, todos los impares). |
:nth-last-child |
Selecciona elementos de entre una lista de elementos hermanos, contando hacia atrás desde el final. Los elementos hermanos están relacionados por una fórmula del tipo an+b (por ejemplo, 2n + 1 r_elacionaría en la secuencia el último de los elementos de este tipo con el que se encuentra dos por delante, y así sucesivamente. Todos los impares, contando desde el final). |
:nth-last-of-type |
Selecciona los elementos de entre una lista de elementos hermanos que son de un tipo determinado (por ejemplo, elementos <p> ), contando hacia atrás desde el final. Los elementos hermanos están relacionados por una fórmula del tipo an+b (por ejemplo, 2n + 1 relacionaría en la secuencia el último de los elementos de ese tipo con el que se encuentra dos por delante, y así sucesivamente. Todos los impares, contando desde el final). |
:only-child |
Selecciona un elemento que no tiene elementos hermanos. |
:only-of-type |
Selecciona un elemento que es el único de su tipo entre sus elementos hermanos. |
:optional |
Selecciona los elementos de formulario que son innecesarios. |
:out-of-range |
Selecciona un elemento cuyo valor está fuera de rango. |
:past |
Selecciona los elementos que se encuentran antes del elemento activo. |
:placeholder-shown |
Selecciona el elemento de entrada que muestra texto de marcador de posición. |
:playing |
Selecciona un elemento que representa un audio, un vídeo o un recurso similar que se puede «reproducir» o «pausar», cuando el elemento está «en reproducción». |
:paused |
Selecciona un elemento que representa un audio, un vídeo o un recurso similar que se puede «reproducir» o «pausar» cuando el elemento está «pausado». |
:read-only |
Selecciona los elementos que el usuario no puede modificar. |
:read-write |
Selecciona los elementos que el usuario puede modificar. |
:required |
Selecciona los elementos de formulario que son necesarios. |
:right |
En Paged Media selecciona las páginas de la derecha. |
:root |
Selecciona un elemento que es la raíz del documento. |
:scope |
Selecciona cualquier elemento de ámbito. |
:valid |
Selecciona un elemento como <input> , en un estado válido. |
:target |
Selecciona el elemento al que apunta la URL activa (es decir, cuyo ID coincide con el identificador de fragmento de la URL activo). |
:visited |
Selecciona los enlaces visitados. |
Pseudoelementos
Selector | Descripción |
---|---|
::after |
Selecciona el elemento al que se puede aplicar estilo que aparece a continuación del contenido del elemento que lo origina. |
::before |
Selecciona el elemento al que se puede aplicar estilo que aparece antes del contenido del elemento que lo origina. |
::first-letter |
Selecciona la primera letra del elemento. |
::first-line |
Selecciona la primera línea del elemento de contenido. |
::grammar-error |
Selecciona una parte del documento que contiene un error de gramática indicado por el navegador. |
::selection |
Selecciona la parte del documento que ha sido seleccionada. |
::spelling-error |
Selecciona una parte del documento que contiene un error de ortografía indicado por el navegador. |