data:image/s3,"s3://crabby-images/fb641/fb641a0cf885b853d74d1eaa7fc1f8bb98e1f5f7" alt="A stick figure smiling"
Here's a preview from my zine, Hell Yes! CSS!! If you want to see more comics like this, sign up for my saturday comics newsletter or browse more comics!
data:image/s3,"s3://crabby-images/452e8/452e81e74bca5319e0a024cd74b4d1a4cfe608b8" alt="Image of a comic. To read the full HTML alt text, click "read the transcript"."
read the transcript!
different rules can set the same property
which one gets chosen?
a:visited {
color: purple;
font-size: 1.2em;
}
#start-link {
color: orange;
}
CSS uses the “most specific” selector that matches an element
In our example, the browser will use color: orange
because IDs (like #start-link
) are more specific than pseudoclasses (like :visited
)
TRY ME! CSS can mix properties from different rules
it’ll use this font size:
a:visited {
color: purple;
font-size: 1.2em;
but use this color because #start-link
is more specific:
}
#start-link {
color: orange;
}
how CSS picks the “most specific” rule
a selector with element names:
body div span a {
color:red;
}
loses to a selector with .classes
or :pseudoclasses
:
.sidebar .link {
color: orange;
}
loses to a selector with an #id
:
#header a {
color: purple;
}
loses to an inline style:
style="color: green;
loses to an !important
rule:
"color: blue !important;
(!important
is very hard to override, which makes life hard for your future self!)
Saturday Morning Comics!
Want another comic like this in your email every Saturday? Sign up here!