:empty
Quick Summary for :empty
The :empty CSS pseudo-class represents any element that has no children. Children can be either element nodes or text (including whitespace). Comments, processing instructions, and CSS content do not affect whether an element is considered empty.
Code Usage for :empty
/* Selects any <div> that contains no content */ div:empty {   background: lime; } 
More Details for :empty

:empty

The :empty CSS pseudo-class represents any element that has no children. Children can be either element nodes or text (including whitespace). Comments, processing instructions, and CSS content do not affect whether an element is considered empty.

Note: In Selectors Level 4 the :empty pseudo-class was changed to act like :-moz-only-whitespace, but no browser currently supports this yet.

/* Selects any <div> that contains no content */ div:empty {   background: lime; } 

Syntax

:empty

Examples

HTML

<div class="box"><!-- I will be lime. --></div> <div class="box">I will be pink.</div> <div class="box">   <!-- I will be pink in older browsers because of the whitespace around this comment. --> </div> <div class="box">   <p><!-- I will be pink in all browsers because of the non-collapsible whitespace and elements around this comment. --></p> </div> 

CSS

.box {   background: pink;   height: 80px;   width: 80px; }  .box:empty {   background: lime; } 

Result

Accessibility concerns

Assistive technology such as screen readers cannot parse interactive content that is empty. All interactive content must have an accessible name, which is created by providing a text value for the interactive control's parent element (anchors, buttons, etc.). Accessible names expose the interactive control to the accessibility tree, an API that communicates information useful for assistive technologies.

The text that provides the interactive control's accessible name can be hidden using a combination of properties that remove it visually from the screen but keep it parsable by assistive technology. This is commonly used for buttons that rely solely on an icon to convey purpose.

What is an accessible name? | The Paciello Group Hidden content for better a11y | Go Make Things MDN Understanding WCAG, Guideline 2.4 explanations Understanding Success Criterion 2.4.4 | W3C Understanding WCAG 2.0

Specifications

Specification
Selectors Level 4 # the-empty-pseudo

See also

:-moz-only-whitespace – The prefixed implementation of the changes in Selectors Level 4 :blank

Last modified: Jan 25, 2022, by MDN contributors

Select your preferred language English (US)DeutschEspañolFrançais日本語PolskiPortuguês (do Brasil)Русский中文 (简体) Change language

No Items Found.

Add Comment
Type in a Nick Name here
 
Other Categories in CSS
css
Search CSS
Search CSS by entering your search text above.
Welcome

This is my test area for webdev. I keep a collection of code here, mostly for my reference. Also if i find a good link, i usually add it here and then forget about it. more...

Subscribe to weekly updates about things i have added to the site or thought interesting during the last week.

You could also follow me on twitter or not... does anyone even use twitter anymore?

If you found something useful or like my work, you can buy me a coffee here. Mmm Coffee. ☕

❤️👩‍💻🎮

🪦 2000 - 16 Oct 2022 - Boots
Random Quote
There is no way to happiness. Happiness is the way.
Unknown
Random CSS Property

<angle>

The <angle> CSS data type represents an angle value expressed in degrees, gradians, radians, or turns. It is used, for example, in <gradient>s and in some transform functions.
<angle> css reference