This content originally appeared on CSS-Tricks and was authored by Chris Coyier
I am part of that 82% that got it wrong in Lea’s quiz (tweet version).
Here’s the code:
:root {
--accent-color: skyblue;
}
div {
--accent-color: revert;
background: var(--accent-color, orange);
}
So what background do I expect <div> to have?
My brain goes like this:
- Well,
--accent-coloris declared, so it’s definitely notorange(the fallback). - The value for the background is
revert, so it’s essentiallybackground: revert; - The
backgroundproperty doesn’t inherit though, and even if you force it to, it would inherit from the<body>, not the root. - So…
transparent.
Nope.
Lea:
[Because the value is
revertit] cancels out any author styles, and resets back to whatever value the property would have from the user stylesheet and UA stylesheet. Assuming there is no--accent-colordeclaration in the user stylesheet, and of course UA stylesheets don’t set custom properties, then that means the property doesn’t have a value.Since custom properties are inherited properties (unless they are registered with
inherits: false, but this one is not), this means the inherited value trickles in, which is — you guessed it —skyblue.
Stephen posted a similar quiz the other day:
Again, my brain does it totally wrong. It goes:
- OK, well,
--coloris declared, so it’s not blue (the fallback). - It’s not
redbecause the second declaration will override that one. - So, it’s essentially like
p { color: inherit; }. - The
<p>will inherityellowfrom the<body>, which it would have done naturally anyway, but whatever, it’s stillyellow.
Nope.
Apparently inherit there is actually inheriting from the next place up the tree that sets it, which html does, so green. That actually is now normal inheriting works. It’s just a brain twister because it’s easy to conflate color the property with --color the custom property.
It also might be useful to know that when you actually declare a custom property with @property you can say whether you want it to inherit or not. So that would change the game with these brain twisters!
@property --property-name {
syntax: '<color>';
inherits: false;
initial-value: #c0ffee;
}
The post Custom Property Brain Twisters appeared first on CSS-Tricks. You can support CSS-Tricks by being an MVP Supporter.
This content originally appeared on CSS-Tricks and was authored by Chris Coyier
Chris Coyier | Sciencx (2021-06-25T18:39:46+00:00) Custom Property Brain Twisters. Retrieved from https://www.scien.cx/2021/06/25/custom-property-brain-twisters/
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.