What are CSS Selectors? A Comprehensive Guide
CSS, or Cascading Style Sheets, is a language used to describe the look and formatting of a document written in HTML. With the help of CSS, web developers can separate the content of a page from its presentation, making it easier to maintain, update, and improve the overall design. One of the critical aspects of CSS is the use of selectors. Selectors are patterns that determine which elements on an HTML page the CSS rules should be applied to. In this comprehensive guide, we'll dive into the world of CSS selectors, explore different types of selectors, and learn how to use them effectively.
Getting Started with CSS Selectors
Before we dive into the different types of CSS selectors, it's essential to understand the basic syntax of CSS. A CSS rule consists of two parts: the selector and the declaration block. The selector determines which HTML elements the rule should be applied to, while the declaration block contains one or more declarations, which are made up of a property and a value, separated by a colon. Here's an example:
selector { property: value; }
Now that we understand the basic structure of a CSS rule let's dive into the different types of CSS selectors.
Type Selectors
Type selectors, also known as element selectors or tag selectors, target specific HTML elements by their tag name. For example, to style all the paragraphs in an HTML document, you can use the following CSS rule:
p { color: blue; font-size: 18px; }
In this example, the type selector p
targets all the paragraph elements, changing their color to blue and setting their font size to 18 pixels.
Class Selectors
Class selectors are used to target elements that have a specific class attribute. They are indicated by a period (.
) followed by the class name. In your HTML, you can assign a class attribute to any element:
<p class="intro">This is an introductory paragraph.</p>
To style all elements with the intro
class, you would use the following CSS rule:
.intro { font-weight: bold; font-size: 24px; }
One significant advantage of class selectors is that they can be reused across multiple elements, allowing you to apply the same styles to different parts of your page.
ID Selectors
ID selectors target elements with a specific ID attribute. They are indicated by a hash symbol (#
) followed by the ID name. In your HTML, you can assign an ID attribute to any element:
<p id="main-title">This is the main title of the page.</p>
To style the element with the main-title
ID, you would use the following CSS rule:
#main-title { font-size: 32px; color: red; }
Keep in mind that IDs should be unique within a document, meaning each element should have a different ID value.
Attribute Selectors
Attribute selectors target elements based on the presence or value of their attributes. There are several ways to use attribute selectors:
-
Presence of an attribute: To target elements that have a specific attribute, regardless of its value, use square brackets (
[]
) enclosing the attribute name:[data-toggle] { cursor: pointer; }
In this example, all elements with the
data-toggle
attribute will have a pointer cursor. -
Exact attribute value: To target elements with a specific attribute value, use the equal sign (
=
) within the square brackets:[data-toggle="modal"] { background-color: gray; }
In thisexample, elements with the
data-toggle
attribute and a value of "modal" will have a gray background color. -
Attribute value contains a word: To target elements with an attribute value containing a specific word, use the tilde (
~
) followed by an equal sign (=
) within the square brackets:[class~="highlight"] { color: yellow; }
In this example, elements with a class attribute containing the word "highlight" will have yellow text.
-
Attribute value starts with: To target elements with an attribute value starting with a specific string, use the caret (
^
) followed by an equal sign (=
) within the square brackets:[href^="https://"] { font-weight: bold; }
In this example, elements with an
href
attribute starting with "https://" will have bold text. -
Attribute value ends with: To target elements with an attribute value ending with a specific string, use the dollar sign (
$
) followed by an equal sign (=
) within the square brackets:[src$=".jpg"] { border: 1px solid black; }
In this example, elements with a
src
attribute ending with ".jpg" will have a 1px solid black border. -
Attribute value contains a substring: To target elements with an attribute value containing a specific substring, use the asterisk (
*
) followed by an equal sign (=
) within the square brackets:[href*="example.com"] { text-decoration: underline; }
In this example, elements with an
href
attribute containing "example.com" will have underlined text.
Pseudo-class Selectors
Pseudo-class selectors target elements based on their state or position within the document. They are indicated by a colon (:
) followed by the pseudo-class name. Some common pseudo-classes include:
-
:hover
: Targets an element when the user hovers their cursor over it:a:hover { color: red; }
In this example, anchor elements will change color to red when the user hovers over them.
-
:active
: Targets an element while it is being activated (e.g., when a button is being pressed):button:active { background-color: gray; }
In this example, button elements will have a gray background color while being pressed.
-
:focus
: Targets an element when it has focus (e.g., when a text input is selected):input:focus { border: 2px solid blue; }
In this example, input elements will have a 2px solid blue border when they have focus.
-
:nth-child()
: Targets elements based on their position among sibling elements:li:nth-child(odd) { background-color: lightgray; }
In this example, odd-numbered list items will have a light gray background color.
Pseudo-element Selectors
Pseudo-element selectors target specific parts of an element, such as the first letter or the before/after content. They are indicated by two colons (::
) followed by the pseudo-element name. Some common pseudo-elements include:
-
::first-letter
: Targets the first letter of an element:p::first-letter { font-size: 24px; font-weight: bold; }
In this example, the first letter of each paragraph will have a font size of 24 pixels and be bold.
-
::first-line
: Targets the first line of text within an element:p::first-line { text-transform: uppercase; }
In this example, the first line of text in each paragraph will be displayed in uppercase.
-
::before
: Inserts content before an element:p::before { content: "Note: "; font-weight: bold; }
In this example, the text "Note: " will be inserted before each paragraph, displayed in bold.
-
::after
: Inserts content after an element:p::after { content: "."; }
In this example, a period will be inserted after each paragraph.
Combining Selectors
You can combine different types of selectors to target elements more specifically. Some common techniques include:
-
Descendant selector: Targets elements that are descendants of another element. To do this, simply separate the selectors with a space:
div p { font-size: 18px; }
In this example, all paragraph elements that are descendants of a
div
element will have a font size of 18 pixels. -
Child selector: Targets elements that are direct children of another element. To do this, use the greater-than symbol (
>
) between the selectors:ul > li { list-style-type: disc; }
In this example, all list items that are direct children of an unordered list (
ul
) element will have a disc-style bullet. -
Adjacent sibling selector: Targets elements that are immediately preceded by another element. To do this, use the plus sign (
+
) between the selectors:h1 + p { margin-top: 10px; }
In this example, paragraphs that are immediately preceded by an
h1
element will have a top margin of 10 pixels. -
General sibling selector: Targets elements that are siblings of another element. To do this, use the tilde (
~
) between the selectors:h1 ~ p { margin-left: 20px; }
In this example, all paragraphs that are siblings of an
h1
element will have a left margin of 20 pixels.
FAQ
Q: What is the difference between a class and an ID selector?
A: Both class and ID selectors target elements based on their attributes, but there are some key differences:
- Class selectors are indicated by a period (
.
) followed by the class name, while ID selectors are indicated by a hash symbol (#
) followed by the ID name. - Classes can be used multiple times within a document, while IDs should be unique.
- An element can have multiple classes but only one ID.
Q: Can I combine multiple selectors in one CSS rule?
A: Yes, you can group multiple selectors by separating them with a comma (,
). The CSS rule will apply to all elements that match any of the selectors:
h1, h2, h3 { font-family: Arial, sans-serif; }
In this example, the font-family
property will be applied to h1
, h2
, and h3
elements.
Q: What is the difference between a pseudo-class and a pseudo-element?
A: Pseudo-classes target elements basedon their state or position within the document, while pseudo-elements target specific parts of an element. Pseudo-classes are indicated by a single colon (:
) followed by the pseudo-class name, while pseudo-elements are indicated by two colons (::
) followed by the pseudo-element name.
Q: What is specificity, and how does it affect CSS selectors?
A: Specificity is a set of rules that determine which CSS rule should take precedence when multiple rules target the same element. Specificity is based on the type of selectors used in a CSS rule. In general, the order of specificity, from highest to lowest, is:
- Inline styles (styles applied directly to an HTML element using the
style
attribute) - ID selectors
- Class, attribute, and pseudo-class selectors
- Type, pseudo-element, and universal selectors
When two CSS rules target the same element and have conflicting properties, the rule with the highest specificity takes precedence. If both rules have the same specificity, the rule that appears later in the stylesheet will be applied.
Q: What is the universal selector, and how is it used?
A: The universal selector, represented by an asterisk (*
), targets all elements in a document. It can be used on its own or in combination with other selectors to target specific elements or groups of elements:
* { box-sizing: border-box; } div * { padding: 10px; }
In the first example, the box-sizing
property is applied to all elements in the document. In the second example, a padding
of 10 pixels is applied to all elements that are descendants of a div
element.
Sharing is caring
Did you like what Mehul Mohan wrote? Thank them for their work by sharing it on social media.
No comments so far
Curious about this topic? Continue your journey with these coding courses: