我有一个结构CSS嵌套的问题
<div id ="page" class="item-page">
<table id="schedule">
</table>
</div>
如何将我放在样式信息#附表
难道是像
#page .item-page #schedule{
// css goes here
}
我有一个结构CSS嵌套的问题
<div id ="page" class="item-page">
<table id="schedule">
</table>
</div>
如何将我放在样式信息#附表
难道是像
#page .item-page #schedule{
// css goes here
}
关闭!这将是#page.item-page #schedule { ... }
。
只是#page #schedule
会正常工作。
在你的代码,#page
和.item-page
是相同的元素,所以如果你在你选择使用这两个你就必须绑在一起,他们就是这样,#page.item-page
而不是将它们之间的空间,这表明二是第一个孩子。
因此,尽管#page #schedule
表示此:
<div id="page" class="item-page">
<table id="schedule"></table>
</div>
#page .item-page #schedule
实际上代表了这一点:
<div id="page">
<div class="item-page">
<table id="schedule"></table>
</div>
</div>
你不使用一遍又一遍的IDS(你不应该)假设,你可以只请参考您的没有嵌套选择器的表格:
#schedule {
border-collapse: collapse;
}
#page.item-page #schedule{
// css goes here
}
或只是
#schedule{
// css goes here
}
由于您使用的ID 和id必须是每页独一无二的,你可以直接使用代替:
#schedule{
// css goes here
}
您可以有几种方法做到这一点:
简单:
#schedule {
}
ID Selector
#page #schedule {
}
div#page table#schedule {
}
Class Selector
.item-page #schedule {
}
div.item-page #schedule {
}
Both
div#page.item-selector table#schedule {
}
您应该specificity阅读起来。和inheritance总之,没有理由做那个具体的事情。
CSS从右向左解析你的规则,所以这里是浏览器级别发生的事情。
#schedule
- >浏览器说:“好的,任何与ID”日程安排“,哦,这就是这张桌子,明白了。
.item-page #schedule
浏览器说:“嗯......知道了,此表中,当存在内部与类东西‘项目页面’那......还只是这个浏览器。
#page .item-page #schedule
嗯..所以什么id为“时间表”那里面的“项目页面”那里面的“#page” ...... 等等!这不存在!
#schedule{
//css
}
就绰绰有余了。
如果你想继承的例子:
.item-page table{}
会影响.item页内部的任何表
.item-page>table{}
会影响任何表,它是.item页的直接子
看到一些网站,我会说他们*应该*是唯一的:) –
@Sarfraz:你说:'id是每个元素每页独一无二的'。但是不应该在页面时间里使用“id”? – PeeHaa
@PeeHaa:只有在不同的页面上共同使用相同的id名称时。在这种情况下,你可以使用'#page#schedule',但是拥有唯一的名字总是一个好主意。 – Sarfraz