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_classis located directly inside thediv, hence a parent-child relationship is established between both elements.Not selected
Thisp.some_classis contained by ablockquotewithin thediv, rather than thedivitself. Although thisp.some_classis a descendant of thediv, it's not a child; it's a grandchild.Consequently, while
div > p.some_classwon't match this element,div p.some_classwill, 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