Css - 浮动布局
css - 浮动
浮动布局 float
取值:left | right | none
设置给:块元素、行内元素、行内块元素
作用:利用float属性可设置元素的浮动,使元素可以在一行上显示。虽然浮动主要是应用于块元素,但行内元素其实也可以浮动,但行内元素本来就是一行显示,所以也没有这个必要
浮动布局的特点
1.一旦元素浮动,它就会脱离标准文档流。它会悬在它原来的位置上面,也即它原来占据的位置被腾空。
2.浮动元素对它前面的兄弟元素无任何影响,只对它后面的兄弟元素有影响。由于它已经脱离了正常文档流,它腾空的位置就会被其它正常元素占据。比如:两个尺寸相同的兄弟div,A在前,B在后,当A向左浮动后,B就会占据A的位置,但由于A悬浮在B上面,所以会看不到B。看起来就是两个盒子处在了同一个位置。但是如果它下面的元素是行内/行内块元素,则浮动的块元素会与它们并列显示,不会发生重叠
3.只有当元素全部浮动后才会并排显示,只要中间有未浮动的div挡路,由于未浮动的div是独占一行,这就会导致后面的浮动元素在下一行显示而非并排。比如:三个兄弟div,A向左浮动、B不浮动、C向左浮动,则AB会重叠、C显示在B原来的位置
4.一行上,某元素浮动后,原本与它基线对齐的元素会变成与它顶对齐,即便多个元素都浮动,同样也是顶线对齐
5浮动元素会受到父元素padding和自身margin的影响会在padding、margin处停止
6.元素一旦浮动就会变成行内块元素,具备行内块的特性。
7.由于子元素浮动后,它会脱离正常文档流,如果一个父元素里的子元素全部脱离的正常流,那么父元素如果没有明确设置一个≥子元素高度的height,则子元素会溢出。
清除浮动
浮动元素除了对父元素高度造成影响以外,它还会对它后面的元素造成影响。可以使用清除浮动来避免这种影响。有四种方法可清除浮动:
width: 500px;
background: black;
}
#son1 {
float: left;
width: 500px;
height: 50px;
background: #010056;
}
#footer {
height: 50px;
background: #ff6a00;
}
<div id="son1"></div>
</div>
<div id="footer"></div>

解决方法1.
设定父div的高≥后代元素的总高度,这样父元素后面的兄弟元素就不再受浮动的影响。
#father{
width:500px;
height:50px;
background:black;
}
父元素有了高度后,footer就可以正常显示在father的下面

解决方法2
设置父元素的overflow,取值hidden、scroll、auto,三个取值在此处的效果是一样的,它使父元素可以根据子元素的总高度自动撑开自身。这种方式与明确设置父元素高度是完全一样的。
#father{
width:500px;
overflow:hidden;
background:black;
}
比如常见的ul列表,一旦其li浮动,ul又没有明确设置≥li的高度,那么ul的高度会变成0。

解决方法3
在最后一个浮动元素的后面放一个空的盒子,设定其css的clear属性,取值有left、right、both。一旦使用了clear清除浮动影响后,父元素可以自动计算出它的高度去正确包裹住它的所有子元素。推荐使用这种方式清除浮动,好处在于它不但清除了son1对son2的影响,同时还使父元素有了高度。
<div id="son1"></div>
<div style="clear:left;"></div>
<div id="son2"></div>
</div>
<div id="footer"></div>
解决方法4
利用伪元素::after,这个伪元素是在父元素所包含的区域内的最后区域附加一个伪元素,用该伪元素清除浮动。
content: "";
display: block;
clear: both;
}
<div id="son1"></div>
::after被放在了此处
</div>
<div id="footer"></div>
解决方法5
在受浮动影响元素上设置overflow
overflow:hidden;
width:20px;
height: 20px;
background: green;
}
<div id="son1"></div>
<div id="son2"></div>
</div>
<div id="footer"></div>
Css - 浮动布局的更多相关文章
- css浮动布局
上次我们一起对盒子模型进行了一定的了解,今天我们就对css浮动布局做一下研究.首先我们来了解一下网页基本布局的三种形式. 首先我们来了解一下什么是网页布局: 网页的布局方式其实就是指浏览器是如何对网页 ...
- CSS浮动布局与菜单栏设计
公司周六停电,终于可以双休了.用周五空余时间再夯实一下css基础,<CSS权威指南>概念性的内容看起来容易犯困,不如实践来得快,动手操作吧. 一.浮动布局 浮动存在问题:浮动使元素脱离文档 ...
- css浮动布局,浮动原理,清除(闭合)浮动方法
css浮动 1.什么是浮动:在我们布局的时用到的一种技术,能够方便我们进行布局,通过让元素浮动,我们可以使元素在水平上左右移动,再通过margin属性调整位置 2.浮动的原理:使当前元素脱离普通流,相 ...
- CSS浮动布局带来的高度塌陷以及其解决办法
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="U ...
- css浮动布局小技巧
父元素如何围住浮动的子元素的三种办法: 一.为父元素应用overflow:hidden. overflow真正用途是防止包含元素被大的内容撑开,设定了宽度之后,包含元素将超过容器的内容减掉:而它还有另 ...
- css 浮动布局,清除浮动
浮动的特性: (1)浮动元素有左浮动(float:left)和右浮动(float:right)两种 (2)浮动的元素会向左或向右浮动,碰到父元素边界.其他元素才停下来 (3)相邻浮动的块元素可以并在一 ...
- div css float布局用法
float的应用与用法 想要知道float的用法,首先你要知道float在网页中的用处. 浮动的目的就是为了使得设置的对象脱离标准文档流. 什么是标准文档流? 网页在解析的时候,遵循于从上向下,从左向 ...
- 前端开发:css基础知识之盒模型以及浮动布局。
前端开发:css基础知识之盒模型以及浮动布局 前言 楼主的蛮多朋友最近都在学习html5,他们都会问到同一个问题 浮动是什么东西? 为什么这个浮动没有效果? 这个问题楼主已经回答了n遍.今天则是把 ...
- html/css 盒子布局 Margin 、Padding 、border 以及 清除浮动的知识 (学习HTML过程中的小记录)
html/css 盒子布局 Margin .Padding .border 以及 清除浮动的知识 (学习HTML过程中的小记录) 作者:王可利(Star·星星) width 是"宽 ...
随机推荐
- php小项目踩坑以及其中的注意点(第二篇)
用户登录页面 1.通过数据库验证用户名和密码(可以将里面要用到的数据库信息,放入到一个config文件中) <?php define('DB_HOST','localhost'); define ...
- Jqgrid pager 关于“local” dataType 动态加载数据分页的研究(没好用的研究结果)
系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...
- 我们数学中常用的自然常数e代表什么?看完长知识了!
我们在学习期间都接触过自然常数e,也知道e ≍ 2.718,学过极限的同学应该也知道 那么大家知道e的含义是什么吗?为啥叫“自然常数”? e的含义可以用一个计算利息的例子来解释. 假如你有1块钱,银行 ...
- twitter分布式主键id生成器
pom <!--生成id--> <dependency> <groupId>com.github.bingoohuang</groupId> <a ...
- vue报错:/node_modules/babel-loader/lib!./node_modules/vue-loader/lib/selector.js?
vue项目中报这样的错误:./node_modules/babel-loader/lib!./node_modules/vue-loader/lib/selector.js? 大部分是因为文件的路径有 ...
- Golang基础语法1
打开cmd命令窗口 保存,编译,执行: 1.保存到一个×××.go的文件(我这里保存到 E:\GoTest\hello.go 下) 2.编译,在命令提示符中执行命令: go build -o E ...
- SpringBoot+Thyemleaf
Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过 ...
- powershell 中常用cmd,unix命令(get-alias)
powershell 中常用cmd,unix命令(get-alias) Get-Content Alias cat -> Get-Content Alias gc -> Get-Conte ...
- 错误 1 未能找到类型或命名空间名称“DataPager”(是否缺少 using 指令或程序集引用?)
鄙人在设计器SearchTab.xaml中添加了如下一个分页控件: <sdk:DataPager x:Name="dataPagerPrj" Grid.Row="3 ...
- Tooltip导致的无法访问已释放对象
最近C#项目中遇到了一个无法访问已释放对象问题,经过反复测试,最终发现问题出在控件Tootip上,因为tootip内部有一个定时器,如果在窗口销毁时,鼠标移动到控件上恰好产生了一个tooltip,就会 ...