关于CSS样式冲突排序的一个小试验

网络整理 - 07-27
按照我们对CSS优先权的理解,最后定义的 CSS 样式将会覆盖在其之前定义的所有已经存在、或与之冲突的样式,比如下面这个例子:

 Example Source Code:

p { color: red; background: yellow }
p { color: green }
  以上的段落最终将呈现绿色的字体,并带有黄色的背景,这是因为最后定义的 color:green 将之前定义的 red 覆盖掉了,至于黄色背景为何没有消失,那是因为第二个 p 的定义中并没有与之冲突的定义,因此它还是有效的。

  我们看运行效果:

 Source Code to Run:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ""><html xmlns=""><head><meta http-equiv="Content-Type" content="text/html; charset=gb2312" /><title></title><style type="text/css">.red { color: red }.green { color: green }.blue { color: blue }</style></head><body><p class="red green blue">站长资讯</p><p class="green blue red">站长学习乐园</p><p class="blue red green"></p></body></html>


  答案是它们都显示为 blue ,也就是蓝色,尽管每个段落都以不同顺序应用了三个段落样式,看上去应该按照应用样式的顺序来决定颜色,比如,第一个显示为 blue ,第二个显示为 red ,第三个显示为 green ,其实这是错误的,这与应用样式的顺序无关,它们最终都听从最后指定的样式,颜色皆为 blue !以后遇到类似的问题请不要苦恼了,因为上面的试验已经给了你答案。