0 Comments

CSS2.0中最常用的十八般兵器(3)

发布于:2013-07-15  |   作者:广州网站建设  |   已聚集:人围观

十一、组选择器(Groupselectors)

当一些元素类型、class或者id都有共同的一些属性,你就可以使用组选择器来避免多次的重复定义。这可以节省不少字节。
例如:定义所有标题的字体、颜色和margin,你可以这样写:

ExampleSourceCode 


  1. h1,h2,h3,h4,h5,h6{  
  2. font-family:"LucidaGrande",Lucida,Arial,Helvetica,sans-serif;  
  3. color:#333;  
  4. margin:1em0;  
  5. }  
  6.  

如果在使用时,有个别元素需要定义独立样式,你可以再加上新的定义,可以覆盖老的定义,例如:

ExampleSourceCode 


  1. h1{font-size:2em;}  
  2.  
  3. h2{font-size:1.6em;}  
  4.  

十二、用正确的顺序指定链接的样式

当你用CSS来定义链接的多个状态样式时,要注意它们书写的顺序,正确的顺序是: :link:visited:hover:active。抽取第一个字母是"LVHA",你可以记忆成"LoVeHAte"(喜欢讨厌)。为什么这么定义,可以参考EricMeyer的《LinkSpecificity》。 如果你的用户需要用键盘来控制,需要知道当前链接的焦点,你还可以定义:focus属性。:focus属性的效果也取决与你书写的位置,如果你希望聚焦元素显示:hover效果,你就把:focus写在:hover前面;如果你希望聚焦效果替代:hover效果,你就把:focus放在:hover后面。

十三、清除浮动

一个非常常见的CSS问题,定位使用浮动的时候,下面的层被浮动的层所覆盖,或者层里嵌套的子层超出了外层的范围。 通常的解决办法是在浮动层后面添加一个额外元素,例如一个div或者一个br,并且定义它的样式为clear:both。这个办法有一点牵强,幸运的是还有一个好办法可以解决,参看这篇文章《HowToClearFloatsWithoutStructuralMarkup》 上面2种方法可以很好解决浮动超出的问题,但是如果当你真的需要对层或者层里的对象进行clear的时候怎么办?一种简单的方法就是用overflow属性,这个方法最初的发表在《SimpleClearingofFloats》,又在《Clearance》和《Supersimpleclearingfloats》中被广泛讨论。 上面那一种clear方法更适合你,要看具体的情况,这里不再展开论述。另外关于float的应用,一些优秀的文章已经说得很清楚,推荐你阅读:《Floatutorial》、《ContainingFloats》和《FloatLayouts》

十四、横向居中(centering)

这是一个简单的技巧,但是值得再说一遍,因为我看见太多的新手问题都是问这个:CSS如何横向居中?你需要定义元素的宽,并且定义横向的margin,如果你的布局包含在一个层(容器)中,你可以这样定义使它横向居中:
广州网站建设,网站建设,广州网页设计,广州网站设计

ExampleSourceCode 


  1. #wrap{  
  2. width:760px;/*修改为你的层的宽度*/  
  3. margin:0auto;  
  4. }  

但是IE5/Win不能正确显示这个定义,我们采用一个非常有用的技巧来解决:用text-align属性。就象这样:

ExampleSourceCode 


  1. body{  
  2. text-align:center;  
  3. }  
  4. #wrap{  
  5. width:760px;/*修改为你的层的宽度*/  
  6. margin:0auto;  
  7. text-align:left;  
  8. }  

第一个body的text-align:center;规则定义IE5/Win中body的所有元素居中(其他浏览器只是将文字居中),第二个text-align:left;是将#warp中的文字居左。

飞机