一些很不錯的css技巧,但也常為人們所忽略
更新時間:2007年05月16日 00:00:00 作者:
一.區(qū)分大小寫
當(dāng)在XHTML中使用CSS,CSS里定義的元素名稱是區(qū)分大小寫的。為了避免這種錯誤,我建議所有的定義名稱都采用小寫。
二.不需要給背景圖片路徑加引號
為了節(jié)省字節(jié),我建議不要給背景圖片路徑加引號,因為引號不是必須的。例如:
background:url("images/***.gif") #333;
可以寫為
background:url(images/***.gif) #333;
如果你加了引號,反而會引起一些瀏覽器的錯誤。
三.用正確的順序指定鏈接的樣式
當(dāng)你用CSS來定義鏈接的多個狀態(tài)樣式時,要注意它們書寫的順序,正確的順序是::link :visited :hover :active。抽取第一個字母是"LVHA",你可以記憶成"LoVe HAte"(喜歡討厭)。
四.清除浮動
一個非常常見的CSS問題,定位使用浮動的時候,下面的層被浮動的層所覆蓋,或者層里嵌套的子層超出了外層的范圍。
通常的解決辦法是在浮動層后面添加一個額外元素,例如一個div或者一個br,并且定義它的樣式為clear: both。這個辦法有一點(diǎn)牽強(qiáng),幸運(yùn)的是還有一個好辦法可以解決,參看這篇文章《How To Clear Floats Without Structural Markup》(注:本站將盡快翻譯此文)。
上面2種方法可以很好解決浮動超出的問題,但是如果當(dāng)你真的需要對層或者層里的對象進(jìn)行clear的時候怎么辦?一種簡單的方法就是用overflow屬性,這個方法最初的發(fā)表在《Simple Clearing of Floats》,又在《Clearance》和《Super simple clearing floats》中被廣泛討論。
上面那一種clear方法更適合你,要看具體的情況,這里不再展開論述。另外關(guān)于float的應(yīng)用,一些優(yōu)秀的文章已經(jīng)說得很清楚,推薦你閱讀:《Floatutorial》、《Containing Floats》和《Float Layouts》
五.橫向居中(centering)
這是一個簡單的技巧,但是值得再說一遍,因為我看見太多的新手問題都是問這個:CSS如何橫向居中?你需要定義元素的寬,并且定義橫向的margin,如果你的布局包含在一個層(容器)中,就象這樣:
body {
text-align:center;
}
#wrap {
width:760px; /* 修改為你的層的寬度 */
margin:0 auto;
text-align:left;
}
六.調(diào)試技巧:層有多大?
當(dāng)調(diào)試CSS發(fā)生錯誤,你就要象排版工人,逐行分析CSS代碼。我通常在出問題的層上定義一個背景顏色,這樣就能很明顯看到層占據(jù)多大空間。有些人建議用border,一般情況也是可以的,但問題是,有時候border 會增加元素的尺寸,border-top和boeder-bottom會破壞縱向margin的值,所以使用background更加安全些。
當(dāng)在XHTML中使用CSS,CSS里定義的元素名稱是區(qū)分大小寫的。為了避免這種錯誤,我建議所有的定義名稱都采用小寫。
二.不需要給背景圖片路徑加引號
為了節(jié)省字節(jié),我建議不要給背景圖片路徑加引號,因為引號不是必須的。例如:
background:url("images/***.gif") #333;
可以寫為
background:url(images/***.gif) #333;
如果你加了引號,反而會引起一些瀏覽器的錯誤。
三.用正確的順序指定鏈接的樣式
當(dāng)你用CSS來定義鏈接的多個狀態(tài)樣式時,要注意它們書寫的順序,正確的順序是::link :visited :hover :active。抽取第一個字母是"LVHA",你可以記憶成"LoVe HAte"(喜歡討厭)。
四.清除浮動
一個非常常見的CSS問題,定位使用浮動的時候,下面的層被浮動的層所覆蓋,或者層里嵌套的子層超出了外層的范圍。
通常的解決辦法是在浮動層后面添加一個額外元素,例如一個div或者一個br,并且定義它的樣式為clear: both。這個辦法有一點(diǎn)牽強(qiáng),幸運(yùn)的是還有一個好辦法可以解決,參看這篇文章《How To Clear Floats Without Structural Markup》(注:本站將盡快翻譯此文)。
上面2種方法可以很好解決浮動超出的問題,但是如果當(dāng)你真的需要對層或者層里的對象進(jìn)行clear的時候怎么辦?一種簡單的方法就是用overflow屬性,這個方法最初的發(fā)表在《Simple Clearing of Floats》,又在《Clearance》和《Super simple clearing floats》中被廣泛討論。
上面那一種clear方法更適合你,要看具體的情況,這里不再展開論述。另外關(guān)于float的應(yīng)用,一些優(yōu)秀的文章已經(jīng)說得很清楚,推薦你閱讀:《Floatutorial》、《Containing Floats》和《Float Layouts》
五.橫向居中(centering)
這是一個簡單的技巧,但是值得再說一遍,因為我看見太多的新手問題都是問這個:CSS如何橫向居中?你需要定義元素的寬,并且定義橫向的margin,如果你的布局包含在一個層(容器)中,就象這樣:
body {
text-align:center;
}
#wrap {
width:760px; /* 修改為你的層的寬度 */
margin:0 auto;
text-align:left;
}
六.調(diào)試技巧:層有多大?
當(dāng)調(diào)試CSS發(fā)生錯誤,你就要象排版工人,逐行分析CSS代碼。我通常在出問題的層上定義一個背景顏色,這樣就能很明顯看到層占據(jù)多大空間。有些人建議用border,一般情況也是可以的,但問題是,有時候border 會增加元素的尺寸,border-top和boeder-bottom會破壞縱向margin的值,所以使用background更加安全些。
相關(guān)文章
CSS expression控制圖片自動縮放效果代碼[兼容 IE,Firefox]
一直以來有個很頭疼的問題困擾著我,那就是圖片縮放的問題,寫到 JS 里面吧,不太容易修改。寫到 CSS 里面吧,IE 6 又不支持 max-width2008-09-09一個老外弄的Clearing floats(清除浮動的方法)
一個老外弄的Clearing floats(清除浮動的方法)...2007-09-09css 不換行 自動換行 強(qiáng)制換行的實現(xiàn)方法
css實現(xiàn)強(qiáng)制不換行/自動換行/強(qiáng)制換行2008-07-07