Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialJiho Song
16,469 PointsWhat is the difference between using ~ and just writing down the specific type name? <CSS>
As I learned sibling combinator,
I came to doubt why we should denote ~ sign after headline.
I mean why we dont use just h1 label { color:white; }
instead of h1 ~label { color:white; }
Is there going to be any significant change if i use like the former one?
2 Answers
Steven Parker
231,268 PointsThese select different things.
Your first example is a descendant selector. If you write "h1 label
" you are targeting only LABEL elements that are contained inside an H1 element (which would be rather unusual).
But your second example is a general sibling selector. If you write "h1 ~ label
" you are targeting LABEL elements that come after an H1 element, and share the same parent with it.
This HTML sample shows the difference in the elements that would be targeted:
<h1>
<label>Your descendant selector would target this label.</label>
</h1>
<label>Your general sibling selector would target this label.</label>
ywang04
6,762 PointsHope this helps.
Jiho Song
16,469 PointsJiho Song
16,469 PointsThanks, it helped
but want just one more clarification.
does that mean
as long as i'm using ~ selectors after h1 no matter where it is placed, will it consider as a sibling selector?
like
<h1> </h1> <p></p> <ul></ul> <ol> </ol>
then, all those <p>, <ul>, <ol> can be regared as a sibling when i call those with ~?
h1~p h1~ul h1~ol
if it is, i feel like the literal meaning of "siblings" is bit deteriorated since sibling should be placed to right after one another.