The descendant selector is a powerful tool in CSS that allows you to target elements based on their position within a document.
It's a bit more complex than the child selector, but the key difference is that it can target elements that are anywhere within a parent element, not just the direct children.
The descendant selector uses a space between the parent and child selectors to indicate the relationship.
In the example, h1 p targets any paragraph that is a descendant of an h1 element.
A unique perspective: Css Selector the Last 2 Child Elements
What is a Descendant Selector?
A descendant selector is a type of combinator selector that matches all elements that are descendants of a specified element.
The first simple selector within a descendant selector represents the ancestor element, which could be a parent element or a parent of a parent element, and so on.
A whitespace character is used as the combinator in a descendant selector, allowing for more than one whitespace character between simple selectors.
On a similar theme: Css Selector That Styles Child If Parent Has an Attribute
You can use descendant selectors with the universal selector, which matches any element, making it possible to select all descendants of a specified element.
The descendant selector will match all elements that are descendants of a specified element, regardless of how many levels deep they are.
For example, a descendant selector will match all four li elements in a fragment of HTML because each of those elements has a ul element as its ancestor.
However, a descendant selector cannot be used to match only the list items in an unordered list, in which case a child selector would be needed.
Additional reading: Css Selector List
Using Descendant Selectors
You can use descendant selectors to style nested elements by specifying the ancestor element followed by the descendant element, separated by a space. For example, "div p { /* your styles here */ }" will apply styles to all paragraph elements inside a div.
To style tables, you can use descendant selectors to select table rows, cells, headers, and other elements based on their relationship with the table element. For example, "table tr:nth-child(even) { /* your styles here */ }" selects every even row in a table.
Expand your knowledge: Css Selector That Targets a Specific Style Declaration
You can use multiple descendant selectors in a single rule, which is useful when you want to style elements that are descendants of more than one type of element. For example, "div p, ul li { /* your styles here */ }" applies styles to both paragraph elements inside divs and list items inside unordered lists.
Here are some examples of using descendant selectors to style different types of elements:
How It Works
The descendant selector is a powerful tool in CSS that allows you to target specific elements based on their position in the HTML document tree.
It works by selecting all elements that match the specified ancestor and descendant elements, regardless of their nesting level.
To use a descendant selector, you need to specify the ancestor element followed by the descendant element, separated by a space. For example, if you want to style all paragraph elements that are descendants of a div element, you would write “div p { /* your styles here */ }”.
Expand your knowledge: Css Ancestor Selector
This will apply the styles to all paragraph elements that are inside a div, no matter how deeply they are nested.
A simple example of this is in an HTML document where the body acts as a parent to h2, div, and two p elements, and the div acts as a parent to three p tags that are its descendants.
Worth a look: Css Selector Select Child of Parent
Styling Nested Elements
You can use a descendant selector to style nested elements by specifying the ancestor element followed by the descendant element, separated by a space. For example, if you want to style all paragraph elements that are descendants of a div element, you would write “div p { /* your styles here */ }”.
This will apply the styles to all paragraph elements that are inside a div, no matter how deeply they are nested. To style nested elements, you need to specify the ancestor element followed by the descendant element, separated by a space.
For instance, if you want to style all list items that are descendants of an unordered list, you would write “ul li { /* your styles here */ }”. This will apply the styles to all list items that are inside an unordered list.
You can also use multiple descendant selectors in a single rule, which is useful when you want to style elements that are descendants of more than one type of element. For example, “div p, ul li { /* your styles here */ }” will apply the styles to both paragraph elements inside divs and list items inside unordered lists.
Here's a summary of how to use a descendant selector to style nested elements:
5.2 Syntax
In CSS, a simple selector can be either a type selector or universal selector followed immediately by zero or more attribute selectors, ID selectors, or pseudo-classes, in any order.
A simple selector matches if all of its components match, which means each part of the selector must be satisfied for the entire selector to match.
The elements of the document tree that match a selector are called subjects of the selector, and they're always a subset of the elements matching the last simple selector.
A selector is a chain of one or more simple selectors separated by combinators, which are white space, ">", and "+". White space may appear between a combinator and the simple selectors around it.
Here are the different types of combinators used in CSS selectors:
One pseudo-element may be appended to the last simple selector in a chain, in which case the style information applies to a subpart of each subject.
Selecting Elements
To style nested elements, you need to specify the ancestor element followed by the descendant element, separated by a space. For example, "div p { /* your styles here */ }" will apply styles to all paragraph elements inside a div, no matter how deeply they are nested.
You can also use descendant selectors to style forms by selecting form elements based on their relationship with the form element. For instance, "form input[type='text'] { /* your styles here */ }" will select all text input fields in a form.
This descendant selector in action example matches all li elements that are descendants of a ul element—that is, every li element that has a ul element as its ancestor.
Broaden your view: Input Css Styling
Styling Tables
Styling tables is a great way to make your data stand out. You can use descendant selectors to style tables by selecting table rows, cells, headers, and other elements based on their relationship with the table element.
For example, you can select every even row in a table with "table tr:nth-child(even) { /* your styles here */ }". This will apply your styles to every second row in the table.
You can also use descendant selectors to style table headers by selecting the "th" element within the "table" element, like this: "table th { /* your styles here */ }". This will apply your styles to every table header in the table.
Applying styles to specific rows or cells can be super helpful when you need to highlight certain data points.
Consider reading: Css Selector Every Child Starting from
Example
Let's take a closer look at how descendant selectors work.
A descendant selector matches all li elements that have a ul element as their ancestor. This means it targets every li element that is nested inside a ul element.
Check this out: How to Find Css Selector of an Element
Adam from SitePoint uses descendant selectors to write his daily newsletter, Versioning, which covers web development news. He's got a beard and loves talking about beer and Star Wars.
Descendant selectors are useful for targeting elements that are nested multiple levels deep in the HTML structure. They're a great tool to have in your CSS toolkit.
Child Selector
The child selector is a powerful tool in CSS that targets only the direct children of a parent element. It's a more specific selector than the descendant selector, which targets all descendants, not just direct children.
A child selector uses the greater-than symbol (>) to indicate the relationship between the parent and child elements. For example, if you want to target the direct children of an element with the class "container", you would use the selector ".container > child".
The child selector is also referred to as a direct descendant selector, emphasizing its focus on direct children only. It's a useful selector to use when you want to apply styles to a specific level of nesting, without affecting further descendants.
Using multiple child combinators is common and can be represented in a single rule, making it easier to write, test, and maintain code. This is because the child selector only moves through a single branch, from child to child.
The child selector is supported in most browsers, but the article doesn't specify which ones exactly.
Testing a Web Page
Testing a web page is a crucial step in ensuring that your CSS selectors are working as intended. To test a web page using CSS selectors, you have two options.
The manual method involves manually inspecting the web page and selecting elements using the browser's developer tools. This method can be time-consuming and prone to human error.
Automation method is a more efficient way to test CSS selectors. It allows you to write scripts that can automatically select elements and test their behavior.
In order to automate testing, you can use the two methods mentioned earlier: manual and automation.
Expand your knowledge: Css Selector Two Classes
Advanced Topics
Descendant selectors can be used to target elements that are children or grandchildren of a specific element. This allows for more precise styling of web pages.
By using descendant selectors, developers can avoid using class or ID selectors, which can become cumbersome with complex layouts. In the example of styling the text of a paragraph within a div, descendant selectors can simplify the code and make it more readable.
Descendant selectors can be chained to target very specific elements, such as a paragraph within a div within another div. This makes them particularly useful for styling complex web page layouts.
The descendant selector syntax is straightforward, using a space to separate the parent and child elements. This can be seen in the example of styling the text of a paragraph within a div, where the code is simply "div p".
Discover more: Checkbox Styling in Css
Frequently Asked Questions
Which combinator is stricter than the descendant selector?
The Child Selector (>) is stricter than the descendant selector, as it only matches elements that are the immediate child of their parent. This makes it a more precise selection tool in CSS.
How do you select immediate children in CSS?
To select immediate children in CSS, use the child combinator ( > ) after the parent element. This allows you to target specific child elements directly.
Sources
- https://www.sitepoint.com/descendant-selector-css-selector/
- https://www.scaler.com/topics/css-descendant-selector/
- https://www.w3.org/TR/CSS21/selector.html%23id-selectors
- https://www.codecademy.com/learn/fscp-web-development-fundamentals/modules/fecp-learn-css-selectors-and-visual-rules/cheatsheet
- https://www.lambdatest.com/blog/css-selectors/
Featured Images: pexels.com