css样式优先级顺序是什么
本文主要介绍"css样式优先级顺序是什么" 有关的知识,希望能够解决您遇到有关问题,下面我们一起来看看这篇 "css样式优先级顺序是什么" 文章。
更好地理解哪些css样式优先使用可以更清晰更有组织的来写css代码,所以让我们看看控制给定html元素的三个css规则:
css优先级计算
css继承
css层叠
学习这些规则将使您的CSS开发更上一层楼。
优先级计算
想象一下,你的html包含一个应用了一类“生物”的段落。您还有以下两个css规则:
p{font-size:12px}
p.bio{font-size:14px}
你希望段落中的文字大小是12px还是14px?在这种情况下你可以猜测它将是14px。css(p.bio)的第二行比你的class=“bio”段更具体。然而,有时优先级并不容易看到。
例如,考虑以下html和css
<divid=“sidebar”>
<pclass=“bio”>文字在这里</p>
</div>
divp.bio{font-size:14px}
#sidebarp{font-size:12px}
乍一看,第一行css可能看起来更具体,但实际上上面的第二行更符合段落的字体大小。这是为什么?
要回答这个问题,我们需要考虑优先级规则。
通过计算css的各种成分并以(a,b,c,d)形式表达它们来计算特异性。这将通过一个例子更清楚,但首先是组件。
元素,伪元素:d=1-(0,0,0,1)
类,伪类,属性:c=1-(0,0,1,0)
Id:b=1-(0,1,0,0)
内联样式:a=1-(1,0,0,0)
id比类更具体而不是元素。
您可以通过计算上述每一项并将a,b,c或d加1来计算优先级。同样重要的是要注意0,0,1,0比0,0,0,15更具体。让我们看一些例子来使计算更清晰。
p:1个元素-(0,0,0,1)
div:1个元素-(0,0,0,1)
#sidebar:1个id-(0,1,0,0)
div#sidebar:1个元素,1个id-(0,1,0,1)
div#sidebarp:2个元素,1个id-(0,1,0,2)
div#sidebarp.bio:2个元素,1个类,1个id-(0,1,1,2)
让我们再看一下上面的例子
divp.bio{font-size:14px}-(0,0,1,2)
#sidebarp{font-size:12px}-(0,1,0,1)
第二个具有更高的优先级,因此优先。
在我们前进之前的最后一点。重要性胜过优先级,当你使用!important标记css属性时,你会覆盖优先级规则等等
divp.bio{font-size:14px!important}
#sidebarp{font-size:12px}
表示上面的第一行css优先于第二行而不是第二行。!important仍然是围绕基本规则的特殊性,如果您了解规则的运作方式,您应该永远不需要。
继承
继承背后的想法相对容易理解。元素从其父容器继承样式。如果将body标签设置为使用color:red,那么除非另有说明,否则正文中所有元素的文本也将为红色。
但是,并非所有css属性都是继承的。例如,边距和填充是非继承属性。如果在div上设置边距或填充,则div内的段落不会继承您在div上设置的边距和填充。该段落将使用默认的浏览器边距和填充,直到您另外声明。
但是,您可以显式设置属性以从其父容器继承样式。例如,您可以声明
p{margin:inherit;填充:继承}
然后你的段落将从它的包含元素继承。
层叠
在最高级别,层叠是控制所有css优先级的,并且如下工作。
1、查找适用于相关元素和属性的所有css声明。
2、按原点和重量排序。Origin指的是声明的来源(作者样式,用户样式,浏览器默认值),权重指的是声明的重要性。(作者的权重大于用户的权重大于默认值。!important比正常声明更重要)
3、计算优先级
4、如果上述所有规则中的两个规则相同,那么最后一个规则获胜。嵌入在html中的CSS总是在外部样式表之后,而不管html中的顺序如何。
上面的#3很可能是你最需要注意的。使用#2只需了解您的样式将覆盖用户设置浏览器的方式,除非他们将规则设置为重要。
还要意识到您的样式将覆盖浏览器默认值,但这些默认值确实存在,并且通常会导致跨浏览器问题。使用重置文件,如EricMeyer的CSS重置或Yahoo的YUI重置CSS有助于将默认样式排除在等式之外。
关于 "css样式优先级顺序是什么" 就介绍到这。希望大家多多支持编程宝库。
本文主要介绍"css3中的calc()函数有什么用" 有关的知识,希望能够解决您遇到有关问题,下面我们一起来看看这篇 "css3中的calc()函数有什么用" 文章。 css3中的calc()是什么 ...