CSS三大特性
层叠继承优先级是我们学习CSS必须掌握的三个特性
CSS层叠性
所谓层叠性是指多重CSS样式的叠加
是浏览器处理冲突的一个能力如果一个属性通过两个相同的选择器设置到同- -个元素上那么这个时候一个属性就会将另一个属性层叠掉
比如先给某个标签指定了内部文字颜色为红色接着又指定了颜色为蓝色此时出现了一一个标签指定了相同样式不同的值的情况这就是样式冲突
-般情况下如果出现样式冲突则会按照CSS书写的顺序以最后的样式为准
CSs最后的执行口诀:长江后浪推前浪,前浪死在沙滩上
CSS继承性
所谓继承性是指书写CSS样式表时,子标签会继承父标签的某些样式如文本颜色和字号想要设置一个可继承的属性只需要将他应用于父元素即可
简单理解就是:子承父业
CSs最后的执行口诀:龙生龙风生风老鼠的孩子会打洞
注意:
恰当地使用继承可以简化代码,降低CSS样式的复杂性子 元素可以继承父元素的样式( text-, font- ,line- 这些元素开头的都可以继承以及color属性)
CSS优先级
定义CSS样式时经常出现两个或更多规则应用在同一元素上这时就会出现优先级的问题在考虑权重时初学者还需要注意-些特殊情况具体如下:
继承样式的权重为0即在嵌套结构中不管父元素样式的权重多大被子元素继承时他的权重都为0也就是说子元素定义的样式会覆盖继承来的样式
形内样式优先应用sty1e属性的元素其行内样式的权重非常高可以理解为远大于100 总之他拥有比上面提到的选择器都大的优先级
权重相同时我们遵循就近原则也就是说靠近元索的样式拥有最大的优先级或者说排在最后的样式优先级最大
CSS定义了一个!important命令该俞令被赋予最大的优先级也就是说不管权重如何以及样式位置的远近!important都具有最大的优先级
CSS特殊性(Specificity)
关于CSS权重我们需要一套计算公式来去计算 这就是CSS Specificity我们称之为CSS特性或非凡性他是一个衡量CSS值优先级的一个标准具体规范如下:
Specificity 用一个四位的数字串(CSS2是三位)来表示更像四个级别值从左到右左面最大一级大于- -级 数位之间没有进制级别之间不可超越
权重是可以叠加的
比如:
注意:数位之间没有进制比如说: 0,0,0,5+0,0,0,5=0,0,0,10而不是0,0,1,0所以不会存在1σTUIVH北江上一T天四伴器的情况
总结优先级:
1.使用了!limportant声明的原则
2.内嵌在HTML元素的style属性里面的声明
3.使用了ID选择器的规则
4.使用了类选择器属性选择器伪元素和伪类选择器的规则
5.使用了元素选择器的规则
6.只包含一个通用选择器的规则
7.同一类选择器则遵循就近原则
总结:权重是优先级的算法层叠是优先级的表现
盒子模型(CSS重点)
其实CSS就是三个大模块:盒子模型浮动定位其余的都是细节要求这三部分无论如何也要学的非常精通所谓盒子模型就是把HTML页面中的元素看做是一个矩形的盒子 也就是一个盛装内容的容器 每个矩形都由元素的内容内边距边框和外边距组成
看透网页布局的本质
网页布局中,我们是如何把里面的文字图片按照UI给我们的效果图排列整齐有序的呢
盒子边框写法总结
内边距(padding)
padding属性用于设置内边距是指边框与内容之间的距离
padding-top:上内边距
padding-right:右内边距
padding-bottom:下内边距
padding-left:左内边距
注意:后面跟几个数值表示的意思不- -样
外边距(margin)
margin属性用于设置外边框设置外边距会在元素之间创建"空白"这段空白通常不能防止其他内容
margin-top:.上外边距
margin-right:右外边距
margin-bottom:下外边距
margin-left:左外边距
margin:.上外边距右外边距下外边距左外边距
取值顺序跟内边距相同
外边距实现盒子居中
可以让-一个盒子实现水平居中需要满足一下两个条件 :
1.必须是块级元素
2.盒子必须指定了宽度(width)
然后就给左右的外边距设置为auto就可以是块级元素水平居中
实际工作中常用这种方式进行网页布局实例代码如下:
.header{ wi dth:960px; margin:0 auto;}
清楚元素的默认内外边距
为了更方便的控制网页中的元素制作网页是可使用如下代码清除元素的默认内外边距
{
padding: 0; / 清除内边距*/
margin: 0; /清除外边距/
}
注意:行内元素是只有左右内外边距的没有.上下内外边距的
外边距合并