如果同個元素有兩個或以上沖突的CSS規(guī)則,瀏覽器有一些基本的規(guī)則來決定哪一個非常特殊而勝出。
它可能不像其它那么重要,大部分案例你不需要擔(dān)心沖突,但大型而且復(fù)雜的CSS文件,或有很多CSS文件組成的,可能產(chǎn)生沖突。
選擇器一樣的情況下后面的會覆蓋前面的屬性。比如:
p { color: blue; }
p元素的元素將是藍(lán)色,因為遵循后面的規(guī)則。
然而,你不可能經(jīng)常用相同的選擇器沖突達(dá)到目的,當(dāng)你使用嵌套選擇器,合理的沖突來了。比如:
p { color: blue; }
也許你看起來p元素在div元素里面的顏色是藍(lán)色,就像后面p元素的規(guī)則,但是第一個選擇器的特性卻是紅色?;旧?,一個選擇器越多特性,樣式?jīng)_突的時候?qū)@示它的樣式。
一組嵌套選擇器的實際特性可以計算出來?;镜模褂肐D選擇器的值是100,使用class選擇器的值是10,每個html選擇器的值是1。它們加起來就可以計算出特性的值。
div p的特性是2(兩個html選擇器)
.tree的特性是10(1個class選擇器)
div p.tree的特性是1+1+10=12,(兩個html選擇器,一個class選擇器)
#baobab的特性是100(1個ID選擇器)
body #content .alternative p的特性是112(兩個html選擇器,一個ID選擇器,一個類選擇器)
按照上面的規(guī)則,div p.tree的特性比div p高,body #content .alternative p又比它們兩個都高。
