我在CSS代码中见过几次“大于”(>),但我不知道它是做什么的。它能做什么?
当前回答
它是CSS子选择器。例子:
Div > p选择Div的所有直接子段落。
看到这个
其他回答
正如其他人所说,它是一个直接子元素,但值得注意的是,这与只是留下一个空格不同……空间是给任何后代的。
<div>
<span>Some text</span>
</div>
Div >span会匹配这个,但不匹配这个:
<div>
<p><span>Some text</span></p>
</div>
为了匹配它,你可以用div>p>span或div span。
它的意思是父母/孩子
例子:
html >身体
也就是说body是HTML的子元素
检查:选择器
它声明了父引用,看看这一页的定义:
http://www.w3.org/TR/CSS2/selector.html#child-selectors
它是CSS子选择器。例子:
Div > p选择Div的所有直接子段落。
看到这个
>选择直接子代
例如,如果你像这样嵌套div:
<div class='outer'>
<div class="middle">
<div class="inner">...</div>
</div>
<div class="middle">
<div class="inner">...</div>
</div>
</div>
你在你的样式表中像这样声明一个CSS规则:
.outer > div {
...
}
您的规则将只应用于那些类为“middle”的div,因为这些div是类为“outer”的元素的直接后代(直接子代)(当然,除非您声明其他更具体的规则覆盖这些规则)。看到小提琴。
div { border: 1px solid black; padding: 10px; } .outer > div { border: 1px solid orange; } <div class='outer'> div.outer - This is the parent. <div class="middle"> div.middle - This is an immediate child of "outer". This will receive the orange border. <div class="inner">div.inner - This is an immediate child of "middle". This will not receive the orange border.</div> </div> <div class="middle"> div.middle - This is an immediate child of "outer". This will receive the orange border. <div class="inner">div.inner - This is an immediate child of "middle". This will not receive the orange border.</div> </div> </div> <p>Without Words</p> <div class='outer'> <div class="middle"> <div class="inner">...</div> </div> <div class="middle"> <div class="inner">...</div> </div> </div>
边注
如果选择器之间有空格,而不是>,则规则将应用于两个嵌套的div。空格更常用,它定义了一个“后代选择器”,这意味着它查找树中任何匹配的元素,而不是像>那样只查找直接的子元素。
注意:IE6不支持>选择器。不过,它在目前所有其他浏览器上都可以运行,包括IE7和IE8。
如果您正在寻找不太常用的CSS选择器,您可能还想查看+,~和[attr]选择器,所有这些都非常有用。
这个页面提供了所有可用选择器的完整列表,以及各种浏览器(主要是IE有问题)对它们的支持的详细信息,以及它们的使用示例。