八.多重class定义
一个标签可以同时定义多个class。例如:我们先定义两个样式,第一个样式背景为#666;第二个样式有10 px的边框。
.one{width:200px;background:#666;}
.two{border:10px solid #F00;}
在页面代码中,我们可以这样调用
1<div class="one" two=""></div>
这样最终的显示效果是这个div既有#666的背景,也有10px的边框。是的,这样做是可以的,你可以尝试一下。
九.使用子选择器(descendant selectors)
CSS初学者不知道使用子选择器是影响他们效率的原因之一。子选择器可以帮助你节约大量的class定义。我们来看下面这段代码:
1<div id="subnav">
2<ul>
3<li class="subnavitem"> <a class="subnavitem" href="#">Item 1</a></li>>
4<li class="subnavitemselected"> <a class="subnavitemselected" href="#"> Item 1</a> </li>
5<li class="subnavitem"> <a class="subnavitem" href="#"> Item 1</a> </li>
6</ul>
7</div>
这段代码的CSS定义是:
div#subnav ul { /* Some styling / }
div#subnav ul li.subnavitem { / Some styling / }
div#subnav ul li.subnavitem a.subnavitem { / Some styling / }
div#subnav ul li.subnavitemselected { / Some styling / }
div#subnav ul li.subnavitemselected a.subnavitemselected { / Some styling */ }
你可以用下面的方法替代上面的代码
1<ul id="subnav">
2<li> <a href="#"> Item 1</a> </li>
3<li class="sel"> <a href="#"> Item 1</a> </li>
4<li> <a href="#"> Item 1</a> </li>
5</ul>
样式定义是:
#subnav { /* Some styling / }
#subnav li { / Some styling / }
#subnav a { / Some styling / }
#subnav .sel { / Some styling / }
#subnav .sel a { / Some styling */ }
用子选择器可以使你的代码和CSS更加简洁、更加容易阅读。