Pseudoclases de ubicación

Seleccionar enlaces según su estado


Existen algunas pseudoclases orientadas a los enlaces o hipervínculos. En este caso, permiten cambiar los estilos dependiendo del comportamiento del enlace. Entre ellas, se encuentran las siguientes:

PseudoclaseDescripción
:any-linkSelecciona un elemento que es un enlace.
:linkSelecciona un elemento que es un enlace no visitado aún.
:visitedSelecciona un elemento que es un enlace visitado anteriormente.
:targetSelecciona un elemento que coincide con el ancla de la URL actual.

Con la pseudoclase :any-link se puede hacer referencia, como dice su nombre, a elementos que sean cualquier tipo de enlaces. En este caso, y si no se delimitan de alguna forma, incluye etiquetas <a> y <area>, ya que ambas se consideran enlaces.

:any-link {
  background: indigo;
  color: white;
  padding: 5px;
}

Por otro lado, la pseudoclase :link permite seleccionar enlaces a páginas que aún no han sido visitadas por el navegador del usuario, lo que puede ser interesante para personalizar el color de este tipo de enlaces. Por defecto, estos enlaces sin visitar suelen ser de color azul.

Veamos un ejemplo donde los cambiamos:

a:link {
  color: green;
  font-weight: bold
}

La pseudoclase :visited

También tenemos la pseudoclase :visited, que se utiliza para seleccionar y dar estilo a los enlaces que hayan sido visitados previamente en el navegador del usuario. Por defecto, estos enlaces suelen ser de color violeta.

a:visited {
  color: purple;
  font-weight: bold;
}

La pseudoclase :target

Con la pseudoclase :target podemos seleccionar un elemento HTML donde su id (ancla) coincida con el ancla que tenemos actualmente en la URL de navegación. Es decir, si en nuestra URL tenemos el ancla #section1, entonces se seleccionará el elemento con id="section1":

:target {
  background: gold;
  color: #333;
  padding: 5px;
}

Ideal para seleccionar cabeceras de secciones a modo de ancla en un documento HTML.

¿Quién soy yo?

Soy Manz, vivo en Tenerife (España) y soy streamer partner en Twitch y profesor. Me apasiona el universo de la programación web, el diseño y desarrollo web y la tecnología en general. Aunque soy full-stack, mi pasión es el front-end, la terminal y crear cosas divertidas y locas.

Puedes encontrar más sobre mi en Manz.dev