文章目录
5、浮动
5.1、标准文档流
文档流
- 网页是一个多层的结构,一层摞着一层
- 通过CSS可以分别为每一层设置样式
- 用户只能看到最顶上一层
- 这些层中,最底下一层称为文档流,文档流是网页的基础,我们所创建的元素默认都是再文档流中进行排列
- 对我我们来说元素又两个状态(在文档流中,不在文档流中)
- 元素在文档流中有什么特点:
- 块元素
- 块元素会在页面独占一行
- 默认宽度是父元素的全部(把父元素撑满)
- 默认高度是被内容撑开的
- 行内元素
- 行内元素不会独占页面的一行,只占自身的大小
- 行内元素在页面中左向右水平排列,如果一行之中不能容纳所有的行内元素,则行内元素会换到第二行继续自左向右(书写习惯一致)
- 行内元素的默认高度和宽度都是被内容撑开
- 块元素
块级元素:独占一行
h1~h6 p div 列表
行内元素
span a img strong.....
行内元素可以被包含在块级元素中,反之,则不可以
5.2、display
<!--
block 块元素
inline 行内元素
inline-block 是块元素但可以内联在一行
-->
<style>
div{
width: 100px;
height: 100px;
border: 1px solid red;
}
span{
width: 100px;
height: 100px;
border: 1px solid rebeccapurple;
display: block;
}
</style>
这个也是一种实现行内元素排列的方式,但大多情况都是用float
5.3、float
-
通过浮动可以使一个元素向其父元素的左侧和右侧移动
使用float属性可以设置元素的浮动
可选值:
- none:默认值,元素不浮动
- left:元素向左浮动
- right:元素向右浮动
-
注意:元素设置浮动后,水平布局的等式便不需要强制成立
-
元素设置浮动后,会完全从文档流中脱离,不再占用文档流的位置,所以元素下边的还在文档流中的元素会自动向上移动
浮动的特点:
- 1、浮动元素会完全脱离文档流,不会占据文档流中的位置
- 2、设置浮动以后元素会向父元素的左侧或右侧移动
- 3、浮动元素默认不会从父元素中移出
- 4、浮动元素向左向右移动时,不会超出它前边的其它浮动元素
- 5、如果浮动元素的上边是一个没有浮动的块元素,则浮动元素无法上移
- 6、浮动元素不会超过它上边的浮动的兄弟元素,最多最多就是和他一样高
- 总结:通过浮动可以制造一些水平方向的布局
浮动的其它特点:
-
元素设置浮动以后,会从文档流中脱离,从文档流中脱离后,元素的一些特点也会发生变化
-
脱离文档流的特点:
- 块元素:
- 1、块元素不再独占页面的一行
- 2、脱离文档流后,块元素的宽度和高度都默认为被内容撑开
- 行内元素:
- 行内元素脱离文档流后就会变成块元素,特点和块元素一样
- 脱离文档流后,就不需要再区分块元素和行内元素了
- 块元素:
5.4、父级边框塌陷的问题
-
在浮动布局中,父元素的高度默认是被子元素撑开的
当子元素浮动后,其会完全脱离文档流,子元素会从文档流中脱离,将会无法撑起父元素的高度,导致父元素高度丢失
-
父元素高度丢失以后,其下的元素会自动上移,导致页面的布局混乱,所以高度塌陷是浮动布局中比较常见的一个问题,这个问题我们必须进行处理!
解决方案:
1.增加父级元素的高度
2.增加一个空的div标签,清除浮动
3.overflow(开启BFC)
在父级元素中增加一个overflow:hidden;
4、父类添加一个伪类:after
小结:
1.浮动元素后面增加空div
简单,代码中尽量避免空div
2.设置父元素的高度
简单,元素假设有了固定的高度,就会被限制
3.overflow
简单,下拉的一些场景不能使用
4.在父类添加伪类(推荐使用)
写法稍微复杂,但没有副作用
5.5、BFC
-
BFC(Block Formatting Context)块级格式化环境
-
BFC是一个CSS中的一个隐含的属性,可以为一个元素开启BFC
开启BFC该元素会变成一个独立的布局区域
-
元素开启BFC后的特点
- 开启BFC的元素不会被浮动元素所覆盖
- 开启BFC的元素和父元素外边距不会重叠
- 开启BFC的元素可以包含浮动的子元素
-
-
可以通过一些特殊的方法来开启元素的BFC
- 1、设置元素的浮动(不推荐)
- 2、将元素设置为行内块元素(不推荐)
- 3、将元素的overflow设置为一个非visible的值(推荐)
- 常用的方式:设置overflow:hidden开启BFC,
5.6、clear
如果我们不希望某个元素因为其它元素浮动的影响而改变位置,可以通过clear属性来清除浮动元素对当前元素所产生的影响
clear:
-
作用:清除浮动元素对当前元素所产生的影响
-
可选值如上图所示
原理:
设置清除浮动以后,浏览器会自动为元素添加一个上外边距,以使其位置不受其它元素的影响
5.7、高度塌陷的最终解决方案(使用伪类)
.box1::after{
content:"";
display:block;
clear:both;
}
完美解决塌陷问题
5.8、clearfix
clearfix这个样式可以同时解决高度塌陷和外边距重叠的问题,当你在遇到这些问题时,直接使用clearfix这个类即可
.clearfix::before,
.clearfix::after{
content:"";
display:table;
clear:both;
}
5.9、对比
-
display
方向不可控制
-
float
浮动起来会脱离标准文档流,所以要解决父级边框塌陷的问题~