Test your skills: The Cascade
The aim of this skill test is to assess whether you understand universal property values for controlling inheritance in CSS.
Note: Click "Play" in the code blocks below to edit the examples in the MDN Playground. You can also copy the code (click the clipboard icon) and paste it into an online editor such as CodePen, JSFiddle, or Glitch. If you get stuck, you can reach out to us in one of our communication channels.
Task 1
In this task, we want you to use one of the special values we looked at in the controlling inheritance section. To write a declaration in a new rule that will reset the background color back to white, without using an actual color value.
Your final result should look like the image below:
Try to update the code below to recreate the finished example:
<div class="container" id="outer">
<div class="container" id="inner">
<ul>
<li class="nav"><a href="#">One</a></li>
<li class="nav"><a href="#">Two</a></li>
</ul>
</div>
</div>
#outer div ul .nav a {
background-color: powderblue;
padding: 5px;
display: inline-block;
margin-bottom: 10px;
}
div div li a {
color: rebeccapurple;
}
Click here to show the solution
One possible solution is as follows:
#outer #inner a {
background-color: initial;
}
There are two things you need to do in this task. First, write a selector for the a
element which is more specific than the selector used to turn the background powderblue. In this solution, this is achieved by using the id
selector, which has very high specificity.
Then you need to remember there are special keyword values for all properties. In this case, using inherit
sets the background color back to be the same as its parent element.
Task 2
In this task, we want you to manipulate the cascade layer order to color the links rebeccapurple
. No editing the lightgreen
declaration!
This task is a stretch goal — it requires knowledge of cascade layers, which we didn't cover in the Handling conflicts article. You can find the information you need to attempt this task at Cascade layers > Determining the precedence based on the order of layers.
Your final result should look like the image below:
Try to update the code below to recreate the finished example:
<div class="container" id="outer">
<div class="container" id="inner">
<ul>
<li class="nav"><a href="#">One</a></li>
<li class="nav"><a href="#">Two</a></li>
</ul>
</div>
</div>
@layer yellow, purple, green;
@layer yellow {
#outer div ul .nav a {
padding: 5px;
display: inline-block;
margin-bottom: 10px;
}
}
@layer purple {
div div li a {
color: rebeccapurple;
}
}
@layer green {
a {
color: lightgreen;
}
}
Click here to show the solution
One possible solution is as follows:
@layer yellow, green, purple;
There is one thing you need to do in this task: change the order of precedence so the declaration for the desired color is in the last declared layer, which is what his solution shows.
You need to remember that unlayered normal styles take precedence over layered normal styles. But, if all styles are within layers — as in the case of this task — styles in later declared layers take precedence over styles declared in earlier layers. Moving the purple layer to the end means it has precedence over the green and yellow layers.