For example:
div > p.some_class {
/* Some declarations */
}
What exactly does the >
sign mean?
Answer
>
is the child combinator, sometimes mistakenly called the direct descendant combinator.1
That means the selector div > p.some_class
only selects paragraphs of .some_class
that are nested directly inside a div
, and not any paragraphs that are nested further within.
An illustration:
Some text here
More text here
What's selected and what's not:
Selected
Thisp.some_class
is located directly inside thediv
, hence a parent-child relationship is established between both elements.Not selected
Thisp.some_class
is contained by ablockquote
within thediv
, rather than thediv
itself. Although thisp.some_class
is a descendant of thediv
, it's not a child; it's a grandchild.Consequently, while
div > p.some_class
won't match this element,div p.some_class
will, using the descendant combinator instead.
1 Many people go further to call it "direct child" or "immediate child", but that's completely unnecessary (and incredibly annoying to me), because a child element is immediate by definition anyway, so they mean the exact same thing. There's no such thing as an "indirect child".
No comments:
Post a Comment