css selectors :first-child selector

CSS Selectors: :first-child Selector

Imagine you’re arranging a photo album and you want the very first photo on each page to have a special border, making it stand out. In web design, the :first-child selector in CSS works similarly. It allows you to style the first element among its siblings, giving you a way to highlight or differentiate the first item in a list, section, or any container.

Pluralsight Logo
Accelerate your tech career
with hands-on learning.
Whether you're a tech newbie or a total pro,
get the skills and confidence to land your next move.
Start 10-Day Free Trial

What is the :first-child Selector?

The :first-child selector is a CSS pseudo-class that targets the first element within its parent. This can be especially useful for creating special styling rules for the first item in a list, the first paragraph in an article, or the first div in a container.

Here’s how it looks:

element:first-child {
  property: value;
}

Why Use the :first-child Selector?

  • Precise Targeting: The :first-child selector allows you to apply styles specifically to the first element within its parent, providing precise control over your designs.
  • Dynamic Styling: It enables you to create dynamic and flexible styles that respond to the structure of your content, enhancing the visual appeal.
  • Simplified Code: Using the :first-child selector can reduce the need for additional classes or IDs, keeping your HTML and CSS clean and maintainable.

Practical Examples

Let’s explore some practical examples to see how the :first-child selector can be used effectively.

Example 1: Styling the First Paragraph

You can style the first paragraph in a section to make it stand out.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>First Paragraph</title>
	
    <style>
	
        p:first-child {
            font-weight: bold;
            color: blue;
        }
		
    </style>
	
</head>
<body>

    <section>
        <p>This is the first paragraph.</p>
        <p>This is the second paragraph.</p>
    </section>
	
</body>
</html>

In this example, the p:first-child selector applies bold text and blue color to the first paragraph within the section, making it stand out.

Example 2: Highlighting the First List Item

You can style the first item in a list to give it special attention.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>First List Item</title>
	
    <style>
	
        li:first-child {
            background-color: yellow;
        }
		
    </style>
</head>
<body>

    <ul>
        <li>First item</li>
        <li>Second item</li>
        <li>Third item</li>
    </ul>
	
</body>
</html>

Here, the li:first-child selector applies a yellow background to the first list item, highlighting it among its siblings.

Example 3: Styling the First Image in a Gallery

You can style the first image in a gallery to give it a special border.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>First Image</title>
	
    <style>
	
        img:first-child {
            border: 5px solid red;
        }
		
    </style>
</head>
<body>

    <div class="gallery">
        <img src="image1.jpg" alt="First Image">
        <img src="image2.jpg" alt="Second Image">
        <img src="image3.jpg" alt="Third Image">
    </div>
	
</body>
</html>

In this example, the img:first-child selector applies a red border to the first image within the gallery, making it visually distinct.

Example 4: Styling the First Div in a Container

You can style the first div in a container to give it unique styling.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>First Div</title>
	
    <style>
	
        .container div:first-child {
            background-color: lightblue;
            padding: 10px;
        }
		
    </style>
</head>
<body>

    <div class="container">
        <div>This is the first div.</div>
        <div>This is the second div.</div>
    </div>
	
</body>
</html>

Here, the .container div:first-child selector applies a light blue background and padding to the first div within the container, distinguishing it from the other divs.

Conclusion

The :first-child selector is a versatile and powerful tool in CSS, allowing you to apply styles specifically to the first element within its parent. Whether you’re highlighting the first paragraph, the first list item, or the first image, the :first-child selector helps you create dynamic, organized, and visually appealing designs. So, the next time you want to style the first element in a sequence, remember the :first-child selector — your key to precise and effective styling.

Scroll to Top