日期:2014-01-03 浏览次数:21269 次
我们看过一些款式表文件的款式名都写的很长,比如:body #header .topbar.logo{...},这是由于利用了元素的承继关系,利用元素名,或者ID名和类名(也就是class名)来精确定位和描述某一个区域的css款式表格式。
初学款式表的人肯定会说,我要精确定位一个区域的款式表,用一个class名不就可以吗,还需求这么麻烦吗?这话说的没错,做只要几个页面的小网页,也确实不用这么麻烦,但是当你规划一个大型网站的时候,你就肯定要利用web元素的承继关系,按照从大区域到小区域的次序来写CSS文档。这就就象画画一样,学过绘画的朋友,都知道,画素描都是先打型然后在铺大色调,最后是深入刻画。CSS文档也是,确定大区域的结构,然后在深入承继和规划。
好了,言归正传,今天要讲的是CSS款式表中承继关系的空格与不空格的问题。先看下面的一个例子:
这是我的CSS文件:
<style type="text/css">
td .a{
color: #006600}
td.b{
color: #FF0000}
</style>
这是我的body元素里的代码:
<table>
<tr>
<td class="b">
<div>
<ul class="a">
<li>这里是标签"li"</li>
</ul>
</div>
</td>
</tr>
</table>
在CSS文件里td后面跟着的class名是 a 和 b ,a里面我定义的字体颜色是绿色,b里面我定义的字体颜色是红色.如今我要说的是,这两个款式表写法都是正确的,类名b没有空格连着元素<td>,而类名a有空格接着元素<td>,运转此代码,你发现页面显示字体为绿色,这说明页面读取了款式表td空格a的内容,由此我们可以推断,页面款式表文件是按照页面元素由里到外的次序来读取的,取近舍远的准绳。
如果我们把款式表td空格a的空格去掉,你会发现,如今页面字体的颜色是读取的款式表b里的内容,字体变为红色的了。这说明了不空格的款式表写法是针对在当前所在元素内而定的,(由于在页面td元素代码里我们只要写class=b,而没有a,所以a款式表的内容将不在页面中表现出来),而有空格的款式表写法是承继了当前元素内某个元素而定,通过反复的几次测试,承继的层级至少是一个层级以上就可以了,具体没有严厉的规定。
置信看到这里,大家对款式表空格与不空格的关系曾经有了一点认识,希望在当前的学习中与大家共勉。如有不正之处,还望包涵,指点!我也只是在任务学习中领悟点认识与大家分享。高手请勿见笑。