(1)对于选择器中给定的各个ID属性值,加1,0,0,0
(2)对于选择器中给定的各个类属性值、属性选择或伪类,加0,0,1,0
(3)对于选择器中给定的各个元素和伪元素,加0,0,0,1
(4)结合符和通配选择器对特殊性没有贡献.其特殊性为0,0,0,0
(5)每个内联声明的特殊性都是1,0,0,0
总结: 复合选择器的权值计算方式为:组成其所有单一选择器的权重累加;同级之前比较个数,不同级别不可跨越。
3.2.3、继承样式的优先级
概述:每一个直接作用于元素的 CSS 规则总是会接管/覆盖(take over)该元素从祖先元素继承而来的规则。
* > 继承属性
3.2.4、例外规则important
概述:当在一个样式声明中使用一个 !important
规则时,此声明将覆盖任何其他声明。
语法:
.box { background-color:red;!important }
注意:一定要优先考虑使用样式规则的优先级来解决问题而不是 !important。
3.3、层叠性
概念:当样式声明发生冲突时,用户代理需要确定样式声明的最终值,既要考虑样式的来源又要考虑样式的特殊声明又要考虑优先级、以及先后顺序 ,这个过程就叫做层叠。
3.3.1、表现
-
开发者样式>浏览器默认样式
-
行间 > id > 类 > 元素名称 > * > 继承样式
-
当优先级与多个 CSS 声明中任意一个声明的优先级相等的时候,CSS 中最后的那个声明将会被应用到元素上,内部和外部样式遵循就近原则。
3.3.2、总结
CSS的层叠性是通过继承和优先级实现
-
样式声明不冲突 (同时应用于元素)
-
样式声明冲突
-
同级选择器,CSS样式中最后定义的声明应用于元素(就近原则)
-
不同级选择器,由选择器优先级决定
-
3、CSS背景
CSS 背景属性用于定义 HTML 元素的背景,通过背景属性我们可以定义元素的背景颜 色、背景图片、背景图片的平铺方式和显示位置等。
3.1 background-color
background-color属性,设置元素的背景颜色。
常用的值:
-
color_name 规定颜色值为颜色名称的背景颜色(比如red)
-
hex_number 规定颜色值为十六进制值的背景颜色(比如 #ff0000)
-
rgb_number 规定颜色值为 rgb 代码的背景颜色(比如 rgb(255,0,0))
-
transparent 默认,背景颜色为透明
注意:背景应用于由内容和内边距、边框组成的区域!
3.2 background -image
background-image 属性,为元素设置背景图像。
background-image:url(" 图片资源路径 ");
常用的值:
-
url(‘URL’) 指向图像的路径
-
none 默认值。不显示背景图像
元素的背景默认绘制区域包括内边距和边框。
默认地,背景图像位于元素的左上角,并在水平和垂直方向上重复。
我们也可以通过 background-repeat 属性可以改变背景图像的平铺方式。
3.3 background -repeat
background-repeat 属性,设置是否或如何重复背景图像。
常用的值:
-
repeat 默认,背景图像将在垂直方向和水平方向重复
-
repeat-x 背景图像将在水平方向重复
-
repeat-y 背景图像将在垂直方向重复
-
no-repeat 背景图像将仅显示一次
3.4、background-position
background-position 属性,设置背景图像(由 background-image 定义)的起始位置。 背景图像如果要重复,将从这一点开始。
语法:
background-position: xpos ypos;
一般来说它有两个值:第一个值表示水平位置,第二个值表示垂直位置。如果仅规定 了一个值,另一个值将是 50%。
取值:
-
关键字:top、bottom、left、right 和 center; 指定图像放置于元素内边距区域的位置,一个对应水平方向,另一个对应垂直方向 例如:左上角为:left top;
-
长度值 指定图像相对于元素内边距区左上角的偏移量。左上角是 0 0,如果设置值为 50px 100px,图像的左上角将在元素内边距区左上角向右 50 像素、向下 100 像素的位置上;
-
百分比 指定百分数值将同时应用于元素和图像,左上角是 0% 0%;右下角是 100% 100%。 如果设置为 50% 50%,图像的中心点将与元素的中心点对齐显示;
3.5、background简写
background是背景复合属性,在一个声明中设置所有背景属性。
语法:
background:bg-color bg-image bg-repeat bg-position; background: red url(“bgimage.jpg”) no-repeat left top;
当使用简写属性时,属性值的顺序为:
-
background-color
-
background-image
-
background-repeat
-
background-attachment
-
background-position
如果某个属性不需要设置,可以省略。