How to Select a Parent Div Based on Its Immediate Child Using CSS?
Styling parent elements based on their children has traditionally been impossible with CSS alone, often requiring JavaScript solutions. We can finally achieve this using pure CSS with the modern :has() pseudo-class selector.
Let’s explore how to use this powerful feature to target parent elements based on their immediate children.
Problem
Many developers face the challenge of selecting a parent element based on its child elements in CSS. Traditionally, this has been impossible with pure CSS alone, as CSS selectors only worked in a forward direction (parent to child). This limitation often forces developers to resort to JavaScript solutions, which add more weight to the project and affect performance.
Solution
Thanks to the modern CSS :has() pseudo-class selector, we can now select parent elements based on their children using pure CSS. This feature is supported in all modern browsers including Chrome 105+, Edge 105+, Safari 15.4+, and Firefox 121+.
Detailed Solution
Using the :has() Selector
The :has() pseudo-class accepts a relative selector list as an argument and selects elements that contain the specified child elements. Here’s how to use it:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | /* Basic syntax */ .parent:has(.child) { /* write styles to the parent div*/ } /* For immediate children */ .parent:has(> .child) { /* write styles to the parent div */ } /* For adjacent siblings */ .parent:has(+ .child) { /* write styles to the parent div */ } |
Example Implementation
Here’s a practical example of how to use :has() to style a parent div based on its immediate child:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | /* Style the parent when it contains a specific child */ .parent:has(> .special-child) { background-color: #f0f0f0; padding: 20px; border: 1px solid #ccc; } /* Hide the parent when followed by a specific element */ .parent:has(+ .next-element) { display: none; } |
Corresponding HTML:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | <!-- Parent will have grey background --> <div class="parent"> <div class="special-child">This parent div will be styled</div> </div> <!-- Parent will be hidden --> <div class="parent"> <div>Content</div> </div> <div class="next-element">This makes the parent div hide</div> |
Browser Support
The :has() selector is supported in:
- Chrome/Edge (version 105+)
- Safari (version 15.4+)
- Firefox (version 121+)
Best Practices
- Always check browser support before implementing
:has()
- Use specific selectors to maintain performance
- Test thoroughly across different browsers
Conclusion
The :has() selector provides a powerful way to select parent elements based on their children, solving a long-standing limitation in CSS. While it’s important to consider browser support, this feature enables more maintainable and JavaScript-free solutions for many common UI patterns.
Recent help desk articles
data:image/s3,"s3://crabby-images/90997/9099711eb0d41c8c65970400f2e04c4d74300ae8" alt="blog"
Greetings! I'm Aneesh Sreedharan, CEO of 2Hats Logic Solutions. At 2Hats Logic Solutions, we are dedicated to providing technical expertise and resolving your concerns in the world of technology. Our blog page serves as a resource where we share insights and experiences, offering valuable perspectives on your queries.
data:image/s3,"s3://crabby-images/e6123/e61233b3ca21ebde64a152a7307d5d9077e3f339" alt="Aneesh ceo"