Distance Descendants and the CSS :not() Selector
The CSS3 :not() pseudo-class is designed to negate a specific selector match. It has been widely implemented across browsers. However, one common misconception surrounding this selector is its applicability to distant descendants.
While :not() successfully negates matches for direct child elements, it does not behave as expected for more distant descendants. As illustrated in the example provided:
div :not(p) { color: red; }
In this snippet, the
element is still inheriting the red color from its parent
, even though it is not a direct descendant of the. This occurs because :not() only directly negates the match for that element, not its descendants.The documentation for :not() in both CSS3 and CSS Selectors Level 4 does not explicitly address this behavior. However, it has been confirmed that this behavior is intentional, and the selector is not meant to support grand-children matching.
Solution
To achieve the desired result of excluding distant descendants from the :not() match, a different method must be employed. One common approach is to specify a color for the specific element you want to exclude, overwriting any inherited values:
div { color: red; } div p { color: black; }CSS Selectors Level 4 Enhancement
CSS Selectors Level 4 proposes an enhancement to the :not() selector, allowing the use of more complex selectors within it. This change will enable the following syntax to correctly negate descendants:
p:not(div p) { color: red; }While this enhancement is not yet widely implemented in browsers, it provides a promising solution for matching and negating distant descendants using :not().
The above is the detailed content of Does CSS :not() Selectively Exclude Distant Descendants?. For more information, please follow other related articles on the PHP Chinese website!

In this week's roundup: Firefox gains locksmith-like powers, Samsung's Galaxy Store starts supporting Progressive Web Apps, CSS Subgrid is shipping in Firefox

In this week's roundup: Internet Explorer finds its way into Edge, Google Search Console touts a new speed report, and Firefox gives Facebook's notification

You’re probably already at least a little familiar with CSS variables. If not, here’s a two-second overview: they are really called custom properties, you set

Building websites is programming. Writing HTML and CSS is programming. I am a programmer, and if you're here, reading CSS-Tricks, chances are you're a

Here's what I'd like you to know upfront: this is a hard problem. If you've landed here because you're hoping to be pointed at a tool you can run that tells

Picture-in-Picture made its first appearance on the web in the Safari browser with the release of macOS Sierra in 2016. It made it possible for a user to pop

Gatsby does a great job processing and handling images. For example, it helps you save time with image optimization because you don’t have to manually

I learned something about percentage-based (%) padding today that I had totally wrong in my head! I always thought that percentage padding was based on the


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

Notepad++7.3.1
Easy-to-use and free code editor

Atom editor mac version download
The most popular open source editor

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.