問:
我已經(jīng)使用CSS定義了超鏈接的樣式,但是瀏覽時(shí)hover(鼠標(biāo)懸停)卻不起作用。為什么會(huì)這樣?是瀏覽器的問題嗎?
答:
雖然你認(rèn)為可能原因是瀏覽器問題,但是更多的可能是你樣式定義時(shí)順序錯(cuò)誤。為了保證能看到不同狀態(tài)下的連接樣式,正確的樣式順序應(yīng)該是:
" link - visited - hover - active "或" LVHA "(縮寫)。
核心內(nèi)容:
每個(gè)選擇符selector都有一個(gè)“specificity”如果兩個(gè)selectors應(yīng)用于同一個(gè)元素,具有較高specificity的選擇符將勝出,具有優(yōu)先權(quán)。例如:
P.hithere {color: green;} /* specificity = 1,1 */
P {color: red;} /* specificity = 1 */
任何設(shè)置了類class=hithere的段落內(nèi)容顯示為綠色而不是紅色。兩個(gè)selectors都設(shè)置了顏色,但是具有更高specificity的選擇符將勝出。
偽類如何影響specificity呢?它們具有完全相同的加權(quán)值,下列樣式具有相同的specificity加權(quán)值:
A:link {color: blue;} /* specificity = 1,1 */
A:active {color: red;} /* specificity = 1,1 */
A:hover {color: magenta;} /* specificity = 1,1 */
A:visited {color: purple;} /* specificity = 1,1 */
這些都是用于超鏈接的樣式設(shè)置。大部分情況下需要同時(shí)設(shè)置其中的幾個(gè)樣式,例如,一個(gè)未被訪問的超鏈接在鼠標(biāo)懸停和點(diǎn)擊時(shí)可設(shè)置“鼠標(biāo)懸?!焙汀笆髽?biāo)激活“兩種狀態(tài)下的不同樣式,由于上述三個(gè)規(guī)則都可應(yīng)用于超鏈接,并且全部選擇符具備相同的specificity,那么根據(jù)規(guī)則,最后一個(gè)樣式“勝出”。所以" active "式樣永遠(yuǎn)也不會(huì)顯示出來,因?yàn)樗偸潜? hover "式樣覆蓋(即" hover "優(yōu)先)?,F(xiàn)在再來分析一下已經(jīng)被訪問過的超鏈接鼠標(biāo)懸停是什么效果,結(jié)果永遠(yuǎn)是purple紫色的:( ,因?yàn)樗? visited "式樣總是優(yōu)先于其它的狀態(tài)樣式規(guī)則(包括" active "和" hover")而顯示。
這就是為什么CSS1推薦樣式順序的原因:
A:link
A:visited
A:hover
A:active
實(shí)際上,開頭兩個(gè)樣式的順序可以調(diào)換,因?yàn)橐粋€(gè)超鏈接不可能同時(shí)存在“未訪問”和“已訪問”兩種狀態(tài)。( :link意思是" unvisited ";我不知道為什么不這樣定義呢.)
CSS2現(xiàn)在允許偽類可以以“聯(lián)合成組”形式出現(xiàn),例如:
A:visited:hover {color: maroon;} /* specificity = 2,1 */
A:link:hover {color: magenta;} /* specificity = 2,1 */
A:hover:active {color: cyan;} /* specificity = 2,1 */
They have the same specificity, but they apply to fundamentally different beasts, and so don't conflict. You can get hover-active combinations, for example.
如何理解本文當(dāng)中所涉及到的“specificity”呢?specificity可以理解未簡(jiǎn)單地連在一起的號(hào)碼字符串,上面的一個(gè)例子:
P.hithere {color: green;} /* specificity = 11 */
P {color: red;} /* specificity = 1 */
這好像是一個(gè)基于十進(jìn)制的簡(jiǎn)單運(yùn)算。然而計(jì)算“specificity”不能使用十進(jìn)制算法,例如你把15種選擇符連在一起使用、它們具有的“specificity”加權(quán)值還是比簡(jiǎn)單的class選擇符低。舉例:
.hello {color: red;} /* specificity = 10 */
HTML BODY DIV UL LI OL LI UL LI OL LI UL LI OL LI (color: green;} /* specificity = 15 */
" 10 "實(shí)際上是一個(gè)“1”后面接著“零”、不是"十",我們可以使用十六進(jìn)制描述前面的樣式規(guī)則的specificitiy,像下面:
.hello {color: red;} /* specificity = 10 */
HTML BODY DIV UL LI OL LI UL LI OL LI UL LI OL LI (color: green;} /* specificity = F */
唯一的問題是如果你想為第二個(gè)樣式規(guī)則增加兩個(gè)或更多的選擇符時(shí),那時(shí)你就可能得到一個(gè)“17”的specificity、會(huì)再一次混淆。事實(shí)上specificity可能是無窮大的,所以為了避免更多的混亂,建議使用逗號(hào)來分隔specificity的值。
建議:反復(fù)練習(xí)specificity的加權(quán)值的計(jì)算,網(wǎng)站CSS的設(shè)置體現(xiàn)了你控制頁面的能力,在動(dòng)態(tài)網(wǎng)站開發(fā)中,CSS的地位也是非常重要的,多看資料,多練習(xí)