In CSS, combinators define relationships between selectors. Instead of selecting elements individually, combinators allow you to target elements based on how they are positioned within the HTML structure.

Software developers are building the future. Become part of them.

There are four main CSS combinators:

  1. Descendant Combinator ( space)
  2. Child Combinator (>)
  3. Adjacent Sibling Combinator (+)
  4. General Sibling Combinator (~)

Let’s break each down—definitions, diagrams, and examples.

1. Descendant Combinator ( – space)

Selects any element nested inside another, at any depth.

✔ Meaning

A B = Select B only if it exists anywhere inside A.

✔ Example HTML

<div class="container">
  <p>First paragraph</p>
  <div>
    <p>Nested paragraph</p>
  </div>
</div>

✔ CSS

.container p {
  color: blue;
}

✔ Output

All <p> elements inside .container—no matter how deeply nested—turn blue.

✔ When to Use

  • Styling items inside a section, card, or container
  • Applying generic rules to nested structures

Learn CSS online

2. Child Combinator (>)

Selects direct children only, not deeper descendants.

✔ Meaning

A > B = Select B only if it is a direct child of A.

✔ Example HTML

<ul class="menu">
  <li>Home</li>
  <li>
    About
    <ul>
      <li>Team</li>
    </ul>
  </li>
</ul>

✔ CSS

.menu > li {
  font-weight: bold;
}

✔ Output

Only the top-level list items (Home and About) become bold, not the nested “Team” item.

✔ When to Use

  • Navigation menus
  • Card layouts with direct children
  • Preventing styles from going too deep

3. Adjacent Sibling Combinator (+)

Selects the immediately next sibling element.

✔ Meaning

A + B = Select B only if it comes right after A.

✔ Example HTML

<h2>Title</h2>
<p>Subtitle paragraph</p>
<p>Another paragraph</p>

✔ CSS

h2 + p {
  margin-top: 0;
}

✔ Output

Only the first <p> after <h2> is affected.

✔ When to Use

  • Removing margin/padding between specific elements
  • Styling the first item after a header or block
  • Form validation messages right after an input field

4. General Sibling Combinator (~)

Selects all siblings that come after a specified element—not just the first one.

✔ Meaning

A ~ B = Select every B that appears after A in the same parent.

✔ Example HTML

<div>
  <h3>Header</h3>
  <p>Paragraph 1</p>
  <p>Paragraph 2</p>
</div>

✔ CSS

h3 ~ p {
  color: green;
}

✔ Output

All <p> elements after <h3> turn green.

✔ When to Use

  • Styling all following elements until the next major block
  • Applying rules to related items
  • Form help-text blocks after an input

Table of CSS Combinators

CombinatorSymbolSelectsExampleMeaning
Descendant(space)Any nested elementdiv pAll <p> inside <div>
Child>Direct childrenul > liOnly top-level <li>
Adjacent Sibling+Next element onlyh1 + pOnly the first <p> after <h1>
General Sibling~All following siblingsh1 ~ pAll <p> after <h1>

Pro Tips for Mastery

✔ 1. Descendant combinators are the most expensive

Use them sparingly in large apps for performance.

✔ 2. Use child combinators when building components

They prevent styles from leaking into unintended nested elements.

✔ 3. Adjacent and general siblings are great for form UX

Example:

input.error + small {
  color: red;
}

✔ 4. Combine combinators for powerful selectors

Example:

.card > h2 + p {
  opacity: 0.7;
}

Meaning: Select the <p> that comes right after <h2> inside .card.

Final Thoughts

CSS combinators are essential for writing clean, predictable, and efficient styles. They allow you to target elements based on their structural relationship, making your CSS more modular and powerful.

Recent Posts

CRUD Operations: The Foundation of Data Management

Every application that stores and manages data relies on a set of basic operations known…

3 days ago

Common PHP Mistakes Every Developer Should Avoid

PHP remains one of the most widely used server-side programming languages, powering platforms such as…

4 days ago

Danfo.js: The JavaScript Data Science Library

Danfo.js is an open-source JavaScript library designed for data manipulation, analysis, and machine learning. It provides…

4 days ago

Common Async/Await Mistakes Every JavaScript Developer Should Avoid

JavaScript's async and await keywords revolutionized asynchronous programming by making asynchronous code look and behave more like synchronous code.…

6 days ago

PGP Encryption And How It Works

Pretty Good Privacy (PGP) is one of the most widely used encryption systems for securing emails,…

1 week ago

How To Migrate from PostgreSQL to MySQL

Database migration is one of the most challenging tasks in software engineering. While both PostgreSQL…

2 weeks ago