利用CSS层叠(cascade)处理样式冲突

2016-02-19 21:22 3 1 收藏

有一种朋友不在生活里,却在生命力;有一种陪伴不在身边,却在心间。图老师即在大家的生活中又在身边。这么贴心的服务你感受到了吗?话不多说下面就和大家分享利用CSS层叠(cascade)处理样式冲突吧。

【 tulaoshi.com - Web开发 】

  即使在不太复杂的样式表中,也可能会有两个或者更多个规则找到同一元素。CSS通过一个叫做层叠(cascade)的过程处理这种冲突。层叠给每个规则分配一个重要程度指数。作者定义的样式具有最高的重要性指数,其次是用户定义的样式。但是为了增强用户的控制能力,用户可以通过为任何规则增加一个!important来提高它的重要性指数,让它的优先级高于任何规则,甚至是比作者的!important还要高。

  因此,层叠重要性指数的次序依次为:

  标记为!important的用户样式

  标记为!important的作者样式

  作者样式

  用户样式

  浏览器/用户代理的默认样式

  为了计算规则的优先级,每种类型的选择符都有一个相应的数值,由于每个选择器都由若干选择符组成,所以选择器的优先指数由选择符对应的数值相加而成,数值越高,优先级越高。CSS中的选择符有四类:

  行内样式(Inline Style),如<span style="color:red"...</span

  ID选择符(ID selectors),如#myid

  类、属性选择符、伪类(Classes, attributes and pseudo-classes),如 .class {...}、[href$=dudo.org]、:hover

  元素(elements)、伪元素选择符(pseudo-elements),如 p {...}、:first-line {...}

  怎么来测量呢?如前所述,它们每一类都有不同的数值表示,其中:

  行内样式为:1000

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

  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)

  看这段代码:

  #wrap #content {color: blue;}

  #content {color: red;}

  <div id="wrap"

  <div id="content"this is a text here</div

  </div

  最终文本会显示什么样的颜色呢?

  是的,样式覆盖只会发生在具有相同优先级的情况下。这个例子中#wrap #content为200,而#content为100,纵使后设定color:red,也不会覆盖掉先前设定的color:blue;。此外,你可以为#content {color: red;}增加!important来看看效果。

  以上都是在少于10个选择符的情况下,可以把这些数值当作十进制来使用和比较,但是,当选择符超过10个(虽然可能性很小)又会怎么样呢?我们参考一个Eric的例子:

  .hello {color: red;} /* specificity = 10 */

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

  HTML BODY DIV UL LI OL LI UL LI OL LI UL LI OL LI {color: green;}

  /* specificity = 15 */

  这里的10并不是“十”,它仅仅代表是一个烦选择符,所以的它的优先级依然要比 15个类型选择符组成的选择器要高。如果换成十六进制的话,就是这个样子

  .hello {color: red;} /* specificity = 10 */

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

  HTML BODY DIV UL LI OL LI UL LI OL LI UL LI OL LI {color: green;}

  /* specificity = 15 */

  但是问题,如果你再添加两个元素,就又变成了11了,还是出现前面的情况。不过你应该始终记得,即使数值“看起来”比较大,它们的排序首先按照类型优先级来决定。

来源:http://www.tulaoshi.com/n/20160219/1625990.html

延伸阅读
    随着的不断发展,声音也逐渐成为了网页制作过程中考虑的一个主要因素。 使用CSS样式表单的方法为网页中加入声音,将有很好的灵活性,提供文档的真正意义上的多重显示模式。 由于声音是在空间上进行传播的,又具有延续性,所以新单位中自然也就有deg角度、grad梯度、rad弧度、ms和s等,剩下的还有就是...
标签: Web开发
一段文本或一张图片,它的周围有一圈光晕,这圈光晕每一秒钟闪烁一次,而当鼠标移到上面时,立即停止闪烁,当鼠标移开时又继续闪烁。这种效果用于那些需要特别引起别人注意的内容上(如:警示、报告新增内容等),能起到较好的效果。 上面这个示例就能实现上面所的效果,由于这里是抓取的一张图片,不能看到动态效果,只要按下面介绍的方...
办公室冲突显然触动了人类情绪的死角,该不该道歉?要不要握手言合?都不是白纸黑字的规则或是记过革职的惩戒可以解决的…… 长时间共处一个办公室,就算面对着冷漠的机械生产线,人与人之间还是会因为升迁、考绩、沟通等等互动,而产生一些不愉快。生产的环境尚且如此,讲究创意与研发的单位,更加容易因为各自领域的坚持...
标签: Web开发
本文介绍如何在Dreamweaver 中使用层叠样式表 (CSS) 设置页面中的文本格式。您可以使用 CSS 以 HTML 无法提供的方式来设置文本格式和定位文本,从而能更加灵活自如地控制页面的外观。  了解 CSS  层叠样式表 (CSS) 是一系列格式设置规则,它们控制 Web 页面内容的外观。使用 CSS 设置页面格式时,内容与表现形式是相...
标签: Web开发
在过去页面上的字体是一成不变的,静静的呆在那。当DHTML(动态网页)出现后,我们能有更多方式控制字体了。一般来说,动态字体的实现核心是CSS(层叠样式表)加JavaScript。使用了以上两项技术后,字体就能产生许多变化。 1.CSS定义字体的标签元素 font-family: 设置字体字族。 span style="font-family: 黑体, 宋体(GB)"田涛/span font-sy...

经验教程

15

收藏

7
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部