Pseudo-clases
Las pseudoclases le permiten seleccionar estados o posiciones específicas de un elemento. Por ejemplo, :hover
selecciona el elemento cuando el puntero del mouse está sobre él, :focus
selecciona el elemento cuando está seleccionado o tiene el foco, :nth-child()
selecciona un elemento secundario específico en un grupo.
Ejemplos:
/* Select all links when hovered over and change the text color */
a:hover {
color: red;
}
/* Select the <input> element when it is focused and change the border */
input:focus {
border: 2px solid blue;
}
/* Select the second element in a group of <li> elements and change the text color */
li:nth-child(2) {
color: green;
}
pseudo-elementos
Los pseudoelementos le permiten crear elementos virtuales para personalizar un elemento existente.
Por ejemplo, ::before
cree ::after
elementos antes y después de un elemento ::first-line
y ::first-letter
seleccione la primera línea y la primera letra de un elemento.
Ejemplos:
/* Add content before each <p> element and style it */
p::before {
content: ">> ";
font-weight: bold;
color: gray;
}
/* Style the first letter of <h1> element */
h1::first-letter {
font-size: 2em;
font-weight: bold;
color: red;
}
combinadores
Los combinadores le permiten combinar selectores para seleccionar elementos en función de su relación. Por ejemplo, element1 element2
selecciona element2
dentro de element1
, element1 > element2
selecciona elementos secundarios directos de element1
, element1 + element2
selecciona element2
inmediatamente después de element1
.
Ejemplos:
/* Select <span> elements inside an element with class "container" */
.container span {
color: purple;
}
/* Select <li> elements that are direct children of <ul> */
ul > li {
list-style-type: square;
color: blue;
}
Selectores de atributos
Los selectores de atributos le permiten seleccionar elementos en función del valor de sus atributos. Por ejemplo, [attribute]
selecciona elementos con el atributo attribute
, [attribute=value]
selecciona elementos con el atributo attribute
igual a value
, [attribute^=value]
selecciona elementos con el atributo attribute
que comienza con value
.
Ejemplos:
/* Select all elements with the attribute data-type */
[data-type] {
font-weight: bold;
color: orange;
}
/* Select all <a> elements with the href attribute starting with "https://" */
a[href^="https://"] {
color: blue;
text-decoration: underline;
}
:not()
selector
El selector le permite seleccionar elementos que no coinciden con un selector específico. Por ejemplo, selecciona elementos que no tienen la clase, selecciona elementos que no tienen la ID. :not()
:not(.class)
class
:not(#id)
id
Ejemplos:
/* Select all <div> elements that do not have the class "hidden" */
div:not(.hidden) {
display: block;
background-color: lightgray;
}
/* Select all <input> elements that do not have the ID "email-input" */
input:not(#email-input) {
border: 1px solid gray;
}
Estos ejemplos demuestran la selección avanzada de elementos en CSS. Puede personalizar y aplicar estas técnicas para diseñar y personalizar elementos en su página web según lo desee.