CSS三大特性总结
1、继承性
概念:父元素向后代元素传递属性的机制
表现:后代元素会继承父元素的属性
总结常用可继承的属性
一般text-,line-,font-,color开头的基本都能继承
a标签不能继承字体颜色color
h标签不能继承font-weight
b.strong不能继承font-weight
i,em不能继承font-style
可继承的属性
font-size
font-family
font-style
font-weight
font
line-height
text-align
text-indentu
color
强制继承
每个CSS属性都接受这些值inherit
表示强制继承”。
作用
恰当地使用继承可以简化代码,降低CSS样式的复杂性
2、优先级
概述:浏览器通过优先级来判断哪些属性值与一个元素最为相关,从而在该元素上应用这些属性值。
样式不冲突,优先级没有意义。当同一个元素有多个冲突声明的时候,优先级才会有意义
行内样式与选择器的优先级
概述:优先级是基于不同种类选择器组成的匹配规则。优先级就是分配给指定的 CSS 声明的一个权重,它由 匹配的选择器中的 每一种选择器类型的 数值 决定
- 选择器优先级与权值相关,权值越大,优先级越高
- 基础选择器的权值:通配符选择器(0)、标签选择器(1)、class选择器(10)、id选择器权值(100)
- 复合选择器的权值是所有单一选择器权值的累加
<div class="box">
<div class="son"></div>
<p></p>
</div>
.box .son{}
权值:
10+10=20
.box p{}
权值:
10+1=11
- 权值相同,后写的会覆盖先写的内容
- 继承样式的优先级为0,子元素设置样式会覆盖继承样式
- 行间样式权值为(1000),优于id选择器
- !important优于行间样式
div{
background-color: lightblue !important;
}
### 2)样式引入方式优先级
- 行间样式优于内部和外部样式,但是高不过!important
- 内部样式和外部样式就近原则
3、层叠性
概念:当样式声明发生冲突时,用户代理需要确定样式声明的最终值,既要考虑样式的来源又要考虑样式的特殊声明又要考虑优先级、以及先后顺序 ,这个过程就叫做层叠
总结
css的层叠性是通过继承性 和 优先级实现
- 样式声明不冲突 (同时应用于元素)
- 样式声明冲突
- 同级选择器,css样式中最后定义的声明应用于元素(就近原则)
- 不同级选择器,由选择器优先级决定
3、css长度单位
- px 像素
- 相对于显示器的屏幕分辨率
- 值是固定
- 计算比较容易
- em
- 相对长度单位,相对于父元素的font-size属性值而言
- 值不固定
- 浏览器默认字号16px,未经调整的浏览器都符合:1em = 16px
- rem
- 相对长度单位,相对于根元素的font-size属性值而言
- 值不固定
- 浏览器默认字号16px,未经调整的浏览器都符合:1rem = 16px
- 是css3新增单位,IE8及更早版本浏览器中不兼容
- % 百分比
- 相对长度单位
- 相对父元素来
html {
/* font-size: 100px; */
font-size: 200px;
}
.wrap {
width: 500px;
height: 500px;
background-color: aqua;
font-size: 20px;
}
.wrap .box {
background-color: tomato;
/* 1.px */
/* width: 100px;
height: 100px; */
/* 2.em 4*20*/
/* width: 4em;
height: 4em; */
/* 3.rem 1*200*/
/* width: 1rem;
height: 1rem; */
/* 4.百分比 */
width: 50%;
height: 50%;
}