为您解读CSS优先级

作者:dh20156 来源:css探索之旅-飘零雾雨的庄园 时间:2009-06-18 18:29:00 

在讲CSS优先级之前,我们得要了解什么是CSS,CSS是用来做什么的。

首先,我们对CSS作一个简单的说明:CSS是层叠样式表(Cascading Style Sheets)的简称。它的规范代表了互联网历史上一个独特的发展阶段。现在对于从事网页制作的朋友来说,应该很少没有听说过CSS了,因为在制作网页过 程中我们经常需要用到。

其次:我们能通过CSS为文档设置丰富且易于修改的外观,以减轻网页制作者的工作负担,从而减轻制作及后期维护的代价。

其实现在还来讲CSS是什么,CSS有什么作用完全是多余的,相信从事网页制作的朋友都已经或多或少的接触过了。

言归正传,我们开始进入今天的话题:

一、什么是CSS优先级?

所谓CSS优先级,即是指CSS样式在浏览器中被解析的先后顺序。

二、CSS优先级规则

既然样式有优先级,那么就会有一个规则来约定这个优先级,而这个“规则”就是本次所需要讲的重点。

样式表中的特殊性描述了不同规则的相对权重,它的基本规则是:

  1. 统计选择符中的ID属性个数。

  2. 统计选择符中的CLASS属性个数。

  3. 统计选择符中的HTML标记名个数。

最后,按正确的顺序写出三个数字,不要加空格或逗号,得到一个三位数(css2.1是用4位数表示)。( 注意,你需要把数字转换成一个以三个数字结尾的更大的数)。相应于选择符的最终数字列表可以很容易确定较高数字特性凌驾于较低数字的。

例如:

  1. 每个ID选择符(#someid),加 0,1,0,0。

  2. 每个class选择符(.someclass)、每个属性选择符(形如[attr=value]等)、每个伪类(形如:hover等)加0,0,1,0。

  3. 每个元素或伪元素(:firstchild)等,加0,0,0,1。

  4. 其它选择符包括全局选择符*,加0,0,0,0。相当于没加,不过这也是一种specificity,后面会解释。

三、特性分类的选择符列表

以下是一个按特性分类的选择符的列表:

选择符

特性值

h1 {color:blue;}

1

p em {color:purple;}

2

.apple {color:red;}

10

p.bright {color:yellow;}

11

p.bright em.dark {color:brown;}

22

#id316 {color:yellow}

100

单从上面这个表来看,貌似不大好理解,下面再给出一张表:

选择符

特性值

h1 {color:blue;}1
p em {color:purple;}1+1=2
.apple {color:red;}10
p.bright {color:yellow;}1+10=11
p.bright em.dark {color:brown;}1+10+1+10=22
#id316 {color:yellow}100

通过上面,就可以很简单的看出,HTML标记的权重是1,CLASS的权重是10,ID的权重是100,继承的权重为0(后面会讲到)。

按这些规则将数字符串逐位相加,就得到最终的权重,然后在比较取舍时按照从左到右的顺序逐位比较。

优先级问题其实就是一个冲突解决的问题,当同一个元素(内容)被CSS选择符选中时,就要按照优先级取舍不同的CSS规则,这其中涉及到的问题其实很多。

说到这里,我们不得不说一下CSS的继承性。

标签:css,优先级,继承
0
投稿

猜你喜欢

  • Navicat For MySQL的简单使用教程

    2024-01-17 12:22:02
  • “验证码”等于“流氓软件”

    2007-10-19 18:29:00
  • Python+PyQT5实现手绘图片生成器

    2022-03-11 11:57:21
  • 关于python中map函数的使用

    2022-10-30 22:43:16
  • JS中判断null、undefined与NaN的方法

    2024-04-19 09:54:05
  • Python实现制作透明背景的电子印章

    2022-01-20 08:11:24
  • python Selenium爬取内容并存储至MySQL数据库的实现代码

    2024-01-13 17:51:28
  • JavaScript判断变量是对象还是数组的方法

    2024-06-24 06:29:37
  • Golang共享变量如何解决问题

    2024-04-26 17:34:09
  • Python selenium get_cookies获取cookie不全的解决方案

    2021-09-17 07:39:52
  • Python pomegranate库实现基于贝叶斯网络拼写检查器

    2021-06-17 19:27:51
  • Python爬虫 批量爬取下载抖音视频代码实例

    2021-08-02 23:25:10
  • asp连接SQL和Access数据代码(asp里的随机函数)

    2013-06-01 20:26:06
  • Mysql注入中的outfile、dumpfile、load_file函数详解

    2024-01-21 01:30:47
  • vue项目中Eslint校验代码报错的解决方案

    2024-05-10 14:09:18
  • 解决PDF 转图片时丢文字的一种可能方式

    2022-06-12 18:29:38
  • SQL Server 2008登录错误:无法连接到(local)解决方法

    2024-01-21 00:39:06
  • Python根据文件名批量转移图片的方法

    2023-03-14 15:00:21
  • python中while循环语句用法简单实例

    2021-12-03 22:34:44
  • ajax Google PageRank3(PR值)查询源代码

    2007-11-04 13:31:00
  • asp之家 网络编程 m.aspxhome.com