2
3
4
5
6
7
div#news {}
div.section {}
div.article {}
div.header {}
div.content {}
div.footer {}
div.aside {}
我们再来看看基于HTML5的实例:
1这是个进步,但仍有一些问题需要解决。在div实例中,我们需要通过class或id属性来调用页面中的元素。这种逻辑将允许我们将样式应用到文档中的任何一个元素上,无论是整体还是个体。例如在div实例中,.section 和 .content元素很容易定位。但是在HTML5实例中,实际文档中会有很多个section元素。其实我们可以添加一些特定的属性选择器来调用那些不同的section元素,不过谢天谢地,我没现在可以用少量的高级CSS选择器来定位不同的section元素。
下面让我们来看看如何在不使用class和id的情况下定位HTML5页面元素的一个实例,我们可以使用三种CSS选择器来定位和辨别实例中的元素。如下:
后代选择器:[CSS 2.1]: E F 兄弟选择器:[CSS 2.1]: E + F 子元素选择器:[CSS 2.1]: E F下面让我们来看看如何不使用class和id而完成对文档中的那些section元素的定位吧:
定位最外层的section元素
考虑到我们的例子并不是一套完整的HTML5代码,所以我们假定在body元素下有个nav元素与section元素是兄弟元素。这样的话,我们就可以向下面代码那样定位最外层的section了:
1定位下一个section元素
作为最外层section元素下的唯一直属子集元素,这个section元素也许可以这样定位:
定位article元素
可以定位article元素的方法有很多,不过最简单的方法当然就是后代选择器了:
定位header、section和footer元素
这三个元素分别在两个地方都出现过,一是在article元素中出现,另一是在aside元素中出现。这种差别能让我们轻松定位每个元素。
或者一起定义:
1到目前为止,我们已经使用CSS2.1选择器排除掉了所有的class和id。那么我们为什么还需要使用CSS3呢?我很高兴你能这么问
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)