CSS教程:1.6 CSS的层叠特性

CSS的全名叫做“层叠样式表”,读者有没有考虑过,这里的“层叠”是什么意思?为什么这个词如此重要,以至于要出现在它的名称里。

CSS的层叠特性确实很重要,但是要注意,千万不要和前面介绍的“继承”相混淆,二者有着本质的区别。实际上,层叠可以简单地理解为“冲突”的解决方案。

例如有如下一段代码,示例文件位于网页学习网CSS教程资源“第1章\16.htm”。

 
 
  1. <html> 
  2. <head> 
  3. <title>层叠特性</title> 
  4. <style type="text/css"> 
  5. p{                
  6.     color:green;      
  7.     }  
  8. .red{  
  9.     color:red;        
  10.     }  
  11. .purple{  
  12.     color:purple;                 
  13.     }  
  14. #line3{  
  15.     color:blue;  
  16.     }  
  17. </style> 
  18. </head> 
  19. <body> 
  20.     <p >这是第1行文本</p> 
  21.     <p class="red">这是第2行文本</p> 
  22.     <p id="line3" class="red">这是第3行文本</p> 
  23.     <p style="color:orange;" id="line3">这是第4行文本</p> 
  24.     <p class="purple red">这是第5行文本</p> 
  25. </body> 
  26. </html> 

代码中一共有5组p标记定义的文本,并在head部分声明了4个选择器,声明为不同颜色。下面的任务是确定每一行文本的颜色。

● 第1行文本没有使用类别样武和ID*F式,因此这行文奉显示为标记选a*8p中定义的绿色。

● 第2行文本使用了类别样式,因此这时已经产生了“冲突”。那么,是按照标记选择器p中定义的绿色显示,还是按照类别选择器中定义的红色显示呢?答案是类别选择器的优先级高于标记选择器,因此显示为类别选择器中定义的红色。

● 第3行文本同时使用了类别样式和ID样式,这又产生了“冲突”。那么,是按照类别选择器中定义的红色显示,还是按照ID选择器中定义的蓝色显示呢?答案是ID选择器的优先级高于类别选择器,因此显示为ID选择器中定义的蓝色。

● 第4行文本同时使用了行内样式和ID样式。那么这时又以哪一个为准呢?答案是行内样式的优先级高于ID样式的优先级,因此显示为行内样式定义的橙色。

● 第5行文本中,使用了两个类别样武,应以哪个为准呢?答案是两个类型选择器的优先级相同,此时以前者为准,“.purple”定义在“.red”的前面,因此显示为“.purpIe”中定
义的紫色。

因此,综上所述,上面这段代码的最示效果如图1所示。WANGYEXX.COM

图1 层叠特性示意图
图1 层叠特性示意图

总结:优先级规则可以表述为:行内样式 > ID样式 > 类别样式 > 标记样式

在复杂的页面中,某一个元素有可能会从很多地方获得样式,例如一个网站的某一级标题整体设置为使用绿色,而对某个特殊栏目需要使用蓝色,这样在该栏目中就需要覆盖通用的样式设置。在很简单的页面中,这样的特殊需求实现起来不会很难,但是如果网站的结构报复杂,就完全有可能使代码变得非常混乱,可能出现无法找到某一个元素的样式来自于哪条规则的情况。因此,必须要充分理解CSS中“层叠”的原理。

注意:计算冲突样式的优先级是一十比较复杂的过程,并不仅仅是上面这个简单的优先级规则可以完全描述的。但是读者可以把捶一个大的原则,就是。越特殊的样式.优先级越高”。

例如,行内样式仅对指定的一个元素产生影响,因此它非常特殊;使用了类别的某种元素,一定是所有该种元素中的一部分,因此它也一定比标记样式特殊;以此类推,ID是针对某一个元素的,因此它一定比应用于多个元素的类别样式特殊。特殊性越高的元素。优先级就越高。

最后再次提醒读者,千万不要混淆了层叠与继承,二者完全不同。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值