CSS样式表层叠(cascade)处理冲突
建站知识 2021-07-03 08:42www.168986.cn长沙网站建设
原文连接http://.dudo./article.asp?id=252
即使在不太复杂的样式表中,也可能会有两个或者更多个规则找到同一元素。CSS通过一个叫做层叠(cascade)的过程处理这种冲突。层叠给每个规则分配一个重要程度指数。作者定义的样式具有最高的重要性指数,是用户定义的样式。为了增强用户的控制能力,用户可以通过为任何规则增加一个!important来提高它的重要性指数,让它的优先级高于任何规则,甚至是比作者的!important还要高。
,层叠重要性指数的次序依次为
-
标记为!important的用户样式
- #wrap#content{color:blue;}
- #content{color:red;}
- <divid="wrap">
- <divid="content">thisisatexthere</div>
- </div>
-
最终文本会显示什么样的颜色呢?
是的,样式覆盖只会发生在具有相同优先级的情况下。这个例子中#wrap #content为200,而#content为100,纵使后设定color:red,也不会覆盖掉先前设定的color:blue;。,你可以为#content {color: red;}增加!important来看看效果。
以上都是在少于10个选择符的情况下,可以把这些数值当作十进制来使用和比较,,当选择符超过10个(虽然可能性很小)又会怎么样呢?我们参考一个Eric的例子:
- .hello{color:red;}/specificity=10/
- HTMLBODYDIVULLIOLLIULLIOLLIULLIOLLI{color:green;}
- /specificity=15/
这里的10并不是“十”,它仅仅代表是一个烦选择符,所以的它的优先级依然要比 15个类型选择符组成的选择器要高。如果换成十六进制的话,就是这个样子
- .hello{color:red;}/specificity=10/
- HTMLBODYDIVULLIOLLIULLIOLLIULLIOLLI{color:green;}
- /specificity=15/
问题,如果你再添加两个元素,就又变成了11了,还是出现前面的情况。不过你应该始终记得,即使数值“看起来”比较大,它们的排序按照类型优先级来决定。
标记为!important的作者样式
作者样式
用户样式
浏览器/用户代理的默认样式
为了计算规则的优先级,每种类型的选择符都有一个相应的数值,由于每个选择器都由若干选择符组成,所以选择器的优先指数由选择符对应的数值相加而成,数值越高,优先级越高。CSS中的选择符有四类 行内样式(Inline Style),如<span style="color:red">...</span>
ID选择符(ID selectors),如#myid
类、属性选择符、伪类(Classes, attributes and pseudo-classes),如 .class {...}、[href$=dudo.]、:hover
元素(elements)、伪元素选择符(pseudo-elements),如 p {...}、:first-line {...}
怎么来测量呢?如前所述,它们每一类都有不同的数值表示,其中
行内样式为1000
ID选择符为0100
类选择符为0010
元素样式为0001
这里要指出的是,所有这些数值都不是10进制数字,1000只是代码它是一个行内样式,
例如,body #wrap p {...},那么它的优先级指数就是 1 100 1=102,而body div#wrap p {...}的优先级指数就是 1 1 100 1 =103。
再看一下其它的例子
{ } 0
li:first-line { } 2 (one element, one pseudo-element)
ul ol li { } 3 (three elements)
ul ol li.red { } 13 (one class, three elements)
style=”” 1000 (one inline styling)
div p { } 2 (two HTML selectors)
div p.sith { } 12 (two HTML selectors and a class selector)
body #darkside .sith p { } 112 (HTML selector, id selector, class selector, HTML selector; 1 100 10 1)
看这段代码
上一篇:保存CSS中的图片的几种方法
下一篇:CSS网页设计技巧十则
长沙网站设计
- 如何进行东阳SEO关键词优化?
- 边坝哪有关键词排名优化:提升你的网站流量与
- 安国百度优化服务:提升您的在线可见性
- 阜康新手做SEO怎么做
- 山西seo网站排名关键词优化:提升您网站曝光率
- 临沂seo网站排名关键词优化:提高你的网站可见
- 广西SEO网站推广怎样付费比较合理
- 双辽SEO网站推广:提升你的网站可见性与流量
- 辽宁企业网站优化购买方式有哪些
- 提升宝清百度SEO排名的实用技巧与策略
- 静宁百度SEO排名:提升您网站曝光率的关键策略
- 彭州百度SEO排名的提升策略和实施指南
- 广南百度关键词SEO:提升网站排名的关键策略
- 辽宁关键词优化怎么做论坛营销
- 吉林百度seo排名如何做到让用户满意
- 内黄百度优化服务:提升在线可见性的关键