Home >Web Front-end >HTML Tutorial >CSS样式优先权_html/css_WEB-ITnose

CSS样式优先权_html/css_WEB-ITnose

WBOY
WBOYOriginal
2016-06-21 08:55:131050browse

    很多时候一个元素的样式并非直接对元素定义,而是对其祖先元素定义,然后通过继承性得到样式。例如,在body中定义的文字的颜色(color)属性,在p元素中也是有效的。这就是样式的继承。

    如果一个元素在多个地方定义了某个样式属性,最后哪个起作用呢?

    例如:在body中定义了字体的大小,元素p的属性style中定义了文字颜色,内部样式表和外部样式表中也都定义了元素p的文字颜色,而且某段文字还用属性id和类名都定义了文字颜色。这样会导致复杂的样式层叠关系,到底谁可以起作用呢?

    如果一个元素被具有相同属性名的多个样式重复作用,也就是出现了样式层叠,CSS需要通过这些样式的选择器的特殊性来进行选择其中的一个样式。选择器越特殊优先权越高,选择器优先权最高的样式被选中。如果最高优先权的有多个,则要看这些样式中哪个样式离这个元素最近,离得最近的被选中。

    选择器的特殊性可以根据下面的规则来确定:

(1)对于id选择器,每个特殊性加0100;

(2)对于类选择器,属性选择器,伪类选择器,每个特殊性加0010;

(3)对于标签选择器和伪元素选择器,每个特殊性加0001;

(4)每个元素只能定义一个行内样式,行内样式的特殊性为1000;

(5)对于结合符和通用选择器,它对特殊性没有贡献,其特殊性为0000;

(6)对于继承得来的选择器没有任何特殊性,其特殊性为0000;

(7)加上!important的样式具有最高的优先权。


优先权比较:

    0100 > 0020;

    0021 > 0020;


特殊性计算例子


Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn