標簽選擇器
標簽選擇器其實就是html代碼中的標簽。<html>、<body>、<h1>、<p>、<img>。
例如下面代碼:
p{font-size:12px;line-height:1.6em;}
類選擇器
語法:
.類選器名稱{css樣式代碼;}
注意:
- 英文圓點開頭
- 其中類選器名稱可以任意起名(但不要起中文噢)
例如:
span class="stress">膽小如鼠</span>
.stress{color:red;}/*類前面要加入一個英文圓點*/
ID選擇器
在很多方面,ID選擇器都類似于類選擇符,但也有一些重要的區別:
- 為標簽設置id="ID名稱",而不是class="類名稱"。
- ID選擇符的前面是井號(#)號,而不是英文圓點(.)。
類和ID選擇器的區別
相同點:可以應用于任何元素
不同點:
- ID選擇器只能在文檔中使用一次。與類選擇器不同,在一個HTML文檔中,ID選擇器只能使用一次,而且僅一次。而類選擇器可以使用多次。
下面代碼是正確的:
<p>三年級時,我還是一個<span class="stress">膽小如鼠</span>的小女孩,上課從來不敢回答老師提出的問題,生怕回答錯了老師會批評我。就一直沒有這個<span class="stress">勇氣</span>來回答老師提出的問題。</p>
而下面代碼是錯誤的:(id 是標識,唯一不可重復)
<p>三年級時,我還是一個<span id="stress">膽小如鼠</span>的小女孩,上課從來不敢回答老師提出的問題,生怕回答錯了老師會批評我。就一直沒有這個<span id="stress">勇氣</span>來回答老師提出的問題。</p>
2、可以使用類選擇器詞列表方法為一個元素同時設置多個樣式。我們可以為一個元素同時設多個樣式,但只可以用類選擇器的方法實現,ID選擇器是不可以的(不能使用 ID 詞列表)。
下面的代碼是正確的
.stress{ color:red; } .bigsize{ font-size:25px; }
<p>到了<span class="stress bigsize">三年級</span>下學期時,我們班上了一節公開課...</p>
下面的代碼是不正確的
#stressid{ color:red; }
#bigsizeid{ font-size:25px; }
<p>到了<span id="stressid bigsizeid">三年級</span>下學期時,我們班上了一節公開課...</p>
子選擇器
還有一個比較有用的選擇器子選擇器,即大于符號(>),用于選擇指定標簽元素的第一代子元素。如右側代碼編輯器中的代碼:
.food>span{border:1px solid red;}
包含(后代)選擇器
包含選擇器,即加入空格,用于選擇指定標簽元素下的后輩元素。
.first span{color:red;}
子選擇器與后代選擇器區別
- 子選擇器(child selector)僅是指它的直接后代,或者你可以理解為作用于子元素的第一代后代。
- 而后代選擇器是作用于所有子后代元素。后代選擇器通過空格來進行選擇,而子選擇器是通過“>”進行選擇。
- 總結:>作用于元素的第一代后代,空格作用于元素的所有后代。
后代選擇器實現預期效果
子選擇器并沒有實現預期效果
通用選擇器
通用選擇器是功能最強大的選擇器,它使用一個(*)號指定,它的作用是匹配html中所有標簽元素,如下使用下面代碼使用html中任意標簽元素字體顏色全部設置為紅色:
* {color:red;}
偽類選擇符
更有趣的是偽類選擇符,為什么叫做偽類選擇符,它允許給html不存在的標簽(標簽的某種狀態)設置樣式,比如說我們給html中一個標簽元素的鼠標滑過的狀態來設置字體顏色:
a:hover{color:red;}
上面一行代碼就是為 a 標簽鼠標滑過的狀態設置字體顏色變紅。這樣就會使第一段文字內容中的“膽小如鼠”文字加入鼠標滑過字體顏色變為紅色特效。
- 關于偽選擇符: 關于偽類選擇符,到目前為止,可以兼容所有瀏鑒器的“偽類選擇符”就是 a 標簽上使用 :hover 了(其實偽類選擇符還有很多,尤其是 css3 中,但是因為不能兼容所有瀏覽器,這里只說這么多)。
- 其實 :hover 可以放在任意的標簽上,比如說 p:hover,但是它們的兼容性也是很不好的,所以現在比較常用的還是 a:hover 的組合。
分組選擇符
當你想為html中多個標簽元素設置同一個樣式時,可以使用分組選擇符(,),如下代碼為右側代碼編輯器中的h1、span標簽同時設置字體顏色為紅色:
h1,span{color:red;}
它相當于下面兩行代碼:
h1{color:red;} span{color:red;}