1.基本語法規(guī)范
分析一個典型CSS的語句:
p {COLOR:#FF0000;BACKGROUND:#FFFFFF}
- 其中"p"我們稱為"選擇器"(selectors),指明我們要給"p"定義樣式;
- 樣式聲明寫在一對大括號"{}"中;
- COLOR和BACKGROUND稱為"屬性"(property),不同屬性之間用分號";"分隔;
- "#FF0000"和"#FFFFFF"是屬性的值(value)。
2.顏色值
顏色值可以用RGB值寫,例如:color : rgb(255,0,0),也可以用十六進(jìn)制寫,就象上面例子color:#FF0000。如果十六進(jìn)制值是成對重復(fù)的可以簡寫,效果一樣。例如:#FF0000可以寫成#F00。但如果不重復(fù)就不可以簡寫,例如#FC1A1B必須寫滿六位。
3.定義字體
web標(biāo)準(zhǔn)推薦如下字體定義方法:
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋體,sans-serif; }
- 字體按照所列出的順序選用。如果用戶的計算機含有Lucida Grande字體,文檔將被指定為Lucida Grande。沒有的話,就被指定為Verdana字體,如果也沒有Verdana,就指定為Lucida字體,依此類推,;
- Lucida Grande字體適合Mac OS X;
- Verdana字體適合所有的Windows系統(tǒng);
- Lucida適合UNIX用戶
- "宋體"適合中文簡體用戶;
- 如果所列出的字體都不能用,則默認(rèn)的sans-serif字體能保證調(diào)用;
4.群選擇器
當(dāng)幾個元素樣式屬性一樣時,可以共同調(diào)用一個聲明,元素之間用逗號分隔,: p, td, li { font-size : 12px ; }
5.派生選擇器
可以使用派生選擇器給一個元素里的子元素定義樣式,例如這樣:
li strong { font-style : italic; font-weight : normal;}
就是給li下面的子元素strong定義一個斜體不加粗的樣式。
6.id選擇器
用CSS布局主要用層"div"來實現(xiàn),而div的樣式通過"id選擇器"來定義。例如我們首先定義一個層
<div id="menubar"></div>
然后在樣式表里這樣定義:
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
其中"menubar"是你自己定義的id名稱。注意在前面加"#"號。
id選擇器也同樣支持派生,例如:
#menubar p { text-align : right; margin-top : 10px; }
這個方法主要用來定義層和那些比較復(fù)雜,有多個派生的元素。
7.類別選擇器
在CSS里用一個點開頭表示類別選擇器定義,例如:
.14px {color : #f60 ;font-size:14px ;}
在頁面中,用class="類別名"的方法調(diào)用:
<span class="14px">14px大小的字體</span>
這個方法比較簡單靈活,可以隨時根據(jù)頁面需要新建和刪除。
8.定義鏈接的樣式
CSS中用四個偽類來定義鏈接的樣式,分別是:a:link、a:visited、a:hover和a : active,例如:
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
a:active {font-weight : bold ;text-decoration : none ;color : #F90 ;}
以上語句分別定義了"鏈接、已訪問過的鏈接、鼠標(biāo)停在上方時、點下鼠標(biāo)時"的樣式。注意,必須按以上順序?qū)?,否則顯示可能和你預(yù)想的不一樣。記住它們的順序是“LVHA”。
1.定義DIV
分析一個典型的定義div例子:
#sample{ MARGIN: 10px 10px 10px 10px;
PADDING:20px 10px 10px 20px;
BORDER-TOP: #CCC 2px solid;
BORDER-RIGHT: #CCC 2px solid;
BORDER-BOTTOM: #CCC 2px solid;
BORDER-LEFT: #CCC 2px solid;
BACKGROUND: url(images/bg_poem.jpg) #FEFEFE no-repeat right bottom;
COLOR: #666;
TEXT-ALIGN: center;
LINE-HEIGHT: 150%; WIDTH:60%; }
說明如下:
- 層的名稱為sample,在頁面中用<div id="sample">就可以調(diào)用這個樣式。
- MARGIN是指層的邊框以外留的空白,用于頁邊距或者與其它層制造一個間距。"10px 10px 10px 10px"分別代表"上右下左"(順時針方向)四個邊距,如果都一樣,可以縮寫成"MARGIN: 10px;"。如果邊距為零,要寫成"MARGIN: 0px;"。注意:當(dāng)值是零時,除了RGB顏色值0%必須跟百分號,其他情況后面可以不跟單位"px"。MARGIN是透明元素,不能定義顏色。
- PADDING是指層的邊框到層的內(nèi)容之間的空白。和margin一樣,分別指定上右下左邊框到內(nèi)容的距離。如果都一樣,可以縮寫成"PADDING:0px"。單獨指定左邊可以寫成"PADDING-LEFT: 0px;"。PADDING是透明元素,不能定義顏色。
- BORDER是指層的邊框,"BORDER-RIGHT: #CCC 2px solid;"是定義層的右邊框顏色為"#CCC",寬度為"2px",樣式為"solid"直線。如果要虛線樣式可以用"dotted"。
- BACKGROUND是定義層的背景。分2級定義,先定義圖片背景,采用"url(../images/bg_logo.gif)"來指定背景圖片路徑;其次定義背景色"#FEFEFE"。"no-repeat"指背景圖片不需要重復(fù),如果需要橫向重復(fù)用"repeat-x",縱向重復(fù)用"repeat-y",重復(fù)鋪滿整個背景用"repeat"。后面的"right bottom;"是指背景圖片從右下角開始。如果沒有背景圖片可以只定義背景色BACKGROUND: #FEFEFE
- COLOR用于定義字體顏色,上一節(jié)已經(jīng)介紹過。
- TEXT-ALIGN用來定義層中的內(nèi)容排列方式,center居中,left居左,right居右。
- LINE-HEIGHT定義行高,150%是指高度為標(biāo)準(zhǔn)高度的150%,也可以寫作:LINE-HEIGHT:1.5或者LINE-HEIGHT:1.5em,都是一樣的意思。
- WIDTH是定義層的寬度,可以采用固定值,例如500px,也可以采用百分比,象這里的"60%"。要注意的是:這個寬度僅僅指你內(nèi)容的寬度,不包含margin,border和padding。但在有些瀏覽器中不是這么定義的,需要你多試試。
我們可以看到邊框是2px的灰色,背景圖片在右下沒有重復(fù),內(nèi)容距離上和左邊框20px,內(nèi)容居中,一切和預(yù)想的一樣。hoho,雖然不好看,但它是最基本的,掌握了它,你就已經(jīng)學(xué)會一半的CSS布局技術(shù)了。就是這樣,不算難吧!(另一半是什么?另一半是層與層之間的定位。我會在后面逐步講解。)
2.CSS2盒模型
自從1996年CSS1的推出,W3C組織就建議把所有網(wǎng)頁上的對像都放在一個盒(box)中,設(shè)計師可以通過創(chuàng)建定義來控制這個盒的屬性,這些對像包括段落、列表、標(biāo)題、圖片以及層<div>。盒模型主要定義四個區(qū)域:內(nèi)容(content)、邊框距(padding)、邊界(border)和邊距(margin)。上面我們講的sample層就是一個典型的盒。對于初學(xué)者,經(jīng)常會搞不清楚margin,background-color,background-image,padding,content,border之間的層次、關(guān)系和相互影響。這里提供一張盒模型的3D示意圖,希望便于你的理解和記憶。
3.輔助圖片一律用背景處理
用XHTML+CSS布局,有一個技術(shù)一開始讓你不習(xí)慣,應(yīng)該說是一種思維方式與傳統(tǒng)表格布局不一樣,那就是:所有輔助圖片都用背景來實現(xiàn)。類似這樣:
BACKGROUND: url(images/bg_poem.jpg) #FEFEFE no-repeat right bottom;
盡管可以用<img>直接插在內(nèi)容中,但這是不推薦的。這里的"輔助圖片"是指那些不是作為頁面要表達(dá)的內(nèi)容的一部分,而僅僅用于修飾、間隔、提醒的圖片。例如:相冊中的圖片、圖片新聞中的圖片,上面的3d盒模型圖片都屬于內(nèi)容的一部分,它們可以用<img>元素直接插在頁面里,而其它的類似logo,標(biāo)題圖片,列表前綴圖片都必須采用背景方式或者其他CSS方式顯示。
這樣做的原因有2點:
- 將表現(xiàn)與結(jié)構(gòu)徹底相分離(參考閱讀另一篇文章:《理解表現(xiàn)與結(jié)構(gòu)相分離》),用CSS控制所有的外觀表現(xiàn),便于改版。
- 使頁面更具有易用性,更有親和力。例如:盲人使用屏幕閱讀機,用背景技術(shù)實現(xiàn)的圖片就不會被朗讀出來
圖片實現(xiàn)在div中垂直居中實現(xiàn)方法:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www./TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www./1999/xhtml">
<head>
<style type="text/css">
#head{}{width:200px;height:100px;margin:0 auto;border:1px solid #000000;}
span.tupian-middle{}{display:block;text-align:center;margin:20px auto;}
</style>
<div id="head"><span class="tupian-middle"><img src="http://www.baidu.com/img/logo-yy.gif" /></span></div>
最近這些天在學(xué)習(xí)CSS+DIV的布局方式,以下是自己練習(xí),通過CSS+DIV布局的頁面代碼:
/**//*定義body中的樣式*/
body {
margin: 0px 0px 0px 0px;
padding: 0px 0px 0px 0px;
font-family: verdana, arial, helvetica, sans-serif,宋體;
color:#FF9900;
background-color: #CCC;
text-align: center;
}
/**//*鏈接樣式*/
a {
text-decoration: none;
font-weight: bold;
color: #666;
outline: none;
}
a:visited {
color: #666;
}
a:active {
color: #666;
}
a:hover {}{
color: #666;
text-decoration: underline;
}
/**//*定義h2字體樣式*/
h2 {
font-size: 18px;
font-weight: bold;
margin-top: 0;
margin-bottom: 0;
}
/**//*定義help中的DIV樣式在屏幕絕對居中顯示*/
#content {
padding: 10px;
margin-top: 20px;
margin-bottom: 20px;
margin-right: auto;
margin-left: auto;
background: #FFF;
border: 2px solid #666;
text-align:left;
width: 600px;
voice-family: "\"}\"";
voice-family:inherit;
width: 580px;
}
/**//*定義answer中的DIV樣式*/
#mydiv{
margin:10px 10px 10px 10px;
padding:10px 10px 10px 10px;
border-top: #ccc 2px solid ;
border-left: #ccc 1px dashed;
border-bottom: #ccc 1px dashed;
border-right: #ccc 1px dashed;
cursor:hand;
}
/**//*圖片絕對居中定位*/
img.imiddle{}{
display:block;text-align:center;margin:20px auto;
}




