基础又重要的浮动(float)
浮动
浮动的概念
- 什么是浮动,他在css中占据什么样的位置
- 网页布局的核心,就是用CSS来摆放盒子位置。如何把盒子摆放到合适的位置?
- 在css中有三种方式来定位位置
- 普通文档标准流方式 (默认方式)
- 浮动流方式 (飘浮)
- 定位方式

- 在css中有三种方式来定位位置
- 在这之中我们讲到的是div浮动方式,元素的浮动顾名思义就是可以飘浮起来的东西,设置了浮动属性的元素会脱离标准流的控制,移动到其父元素中指定的位置。
- 网页布局的核心,就是用CSS来摆放盒子位置。如何把盒子摆放到合适的位置?
- 为什么有浮动?他有什么作用,他的优势和劣势是什么?
- 为什么有浮动
- 浮动在网页中一开始的作用不大,用来实现文字在图片四周达到文字环绕的效果,既然是有用处的自然他就出现了,之后 慢慢的发现浮动很有意思,可以使块元素一行显示,就把更多的功能作用在了页面布局上了

- 浮动在网页中一开始的作用不大,用来实现文字在图片四周达到文字环绕的效果,既然是有用处的自然他就出现了,之后 慢慢的发现浮动很有意思,可以使块元素一行显示,就把更多的功能作用在了页面布局上了
- 优势
- 使得布局的方式 更加多样化适用于自定义布局
- 劣势
- 因为浮动的原因,该元素盒子是飘浮在其他标准流盒子之上的
- 为什么有浮动
CSS浮动属性float详解
- 浮动的几个属性值有那些?他的作用是什么
* 选择器:{声明(属性(float):属性值);}
| 属性值 | 作用 |
|---|---|
| left | 元素盒子左浮动 |
| right | 元素盒子右浮动 |
| none | 元素盒子没有使用浮动(默认值) |
CSS浮动布局
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>三个盒子使用浮动来实现并排效果</title>
<style>
div{
float: left;
width: 200px;
height: 200px;
text-align: center;
}
div::after{
content: "";
line-height: 200px;
}
.box1{
background-color: aqua;
}
.box2{
background-color: red;
}
.box3{
background-color: yellow;
}
</style>
</head>
<body>
<div class="box1"> box 1</div>
<div class="box2"> box 2</div>
<div class="box3"> box 3</div>
</body>
</html>
CSS浮动清除
- 清除浮动的属性:clear;
| 属性值 | 作用 |
|---|---|
| left | 元素盒子清除左浮动(需要给清除浮动的第一个最左边的盒子添加clear:left清除左浮动) |
| right | 元素盒子清除左浮动(需要给清除浮动的第一个最右边的盒子添加clear:right) |
| both | 所有元素盒子清除(需要作用在要清除的浮动元素最下面) |
如果有用浮动,就应该尽量清除浮动
就好比人生苦短,有始有终
世间的繁华,只能一生去观望
美好的愿望,只能一世去实现
一世一轮回
- 为什么要清除浮动?
- 前面也有说过,因为原本浮动是用来做字体图片排版的,之后用来做div布局,必定会有一些不兼容的问题需要解决,虽然是一个缺点,但是不能说浮动元素不好用吧
清除浮动的几种方法
- 给浮动的最后一个标签再额外加上一个标签给上clear:both属性
- 优点: 通俗易懂,书写方便
- 缺点: 添加许多无意义的标签,结构化较差。
- 第一种方式的升级版:通过给高度塌陷的元素添加 :after 伪类元素 相当于在所右子元素浮动元素的最后面添加了一个标签,加上clear:both;优点也体现出来了
- 优点: 符合闭合浮动思想 结构语义化正确
- 缺点: 由于IE低版本浏览器ie7以下不支持:after伪类元素,但是可以通过添加zoom:1来做ie的兼容
- 给父级元素添加overflow属性方法
- 可以通过触发BFC的方式来实现清除浮动效果。
- 可以给父级添加: overflow为 hidden|auto|scroll 都可以实现。
- 注意:none不可以,他不会触发BFC
- 优点: 代码简洁
- 缺点: 内容增多时候容易造成不会自动换行导致内容被隐藏掉,无法显示需要溢出的元素和如果使用auto和scroll会出现滚动条,一般情况下是不需要滚动条的。
通用 万能清浮法
该方法是最兼容的方法了,几乎解决了所有会出现版本问题的方式
.clearAll{
zoom:1; /*因为伪类元素在ie7及以下不兼容的兼容方法*/
}
.clearAll:after{
center:"";
display:block; /* 设置块元素,这样他不会和元素并排,而是最后一个浮动元素的下面*/
clear:both; /* 清除浮动 上面的三个都要有,缺一不可,下面是解决兼容问题*/
overflow:hidden; /*再加上一层保障,就万无一失了*/
visibility:hidden; /*把这个伪元素彻底隐藏,但是他还是存在*/
height:0; /*给这个伪元素加上高度,这样他就算在center里面写内容也不显示*/
}
高度塌陷的产生条件
- 产生条件
- 父级元素因为子级浮动引起内部高度为0 产生的高度塌陷
- 解决方法
- 给父元素加固定高度,使父元素自己撑开
- 给父元素触发BFC来实现父元素被子元素撑开效果
基础又重要的浮动(float)的更多相关文章
- CSS浮动(float,clear)通俗讲解
首先要知道,div是块级元素,在页面中独占一行,自上而下排列,也就是传说中的流.如下图: 可以看出,即使div1的宽度很小,页面中一行可以容下div1和div2,div2也不会排在div1后边,因为d ...
- 经验分享:CSS浮动(float,clear)通俗讲解
很早以前就接触过CSS,但对于浮动始终非常迷惑,可能是自身理解能力差,也可能是没能遇到一篇通俗的教程. 前些天小菜终于搞懂了浮动的基本原理,迫不及待的分享给大家. 写在前面的话: 由于CSS内容比较多 ...
- 【html】【6】div浮动float
我想 当看完上面的必看链接,拥有一定的基础后也得7天左右, 记住 一定要看完,知道它都有什么,没学会不要紧,哪怕只是有个简单的概念也行, 随着后续的使用慢慢深入学习,现在开始div布局. 必看参考: ...
- 经验分享:CSS浮动(float,clear)通俗讲解(转载)
很早以前就接触过CSS,但对于浮动始终非常迷惑,可能是自身理解能力差,也可能是没能遇到一篇通俗的教程. 前些天小菜终于搞懂了浮动的基本原理,迫不及待的分享给大家. 写在前面的话: 由于CSS内容比较多 ...
- 经验分享:CSS浮动(float,clear)通俗讲解 太棒了,清晰明了
很早以前就接触过CSS,但对于浮动始终非常迷惑,可能是自身理解能力差,也可能是没能遇到一篇通俗的教程. 前些天小菜终于搞懂了浮动的基本原理,迫不及待的分享给大家. 写在前面的话: 由于CSS内容比较多 ...
- (转)经验分享:CSS浮动(float,clear)通俗讲解
很早以前就接触过CSS,但对于浮动始终非常迷惑,可能是自身理解能力差,也可能是没能遇到一篇通俗的教程. 前些天小菜终于搞懂了浮动的基本原理,迫不及待的分享给大家. 写在前面的话: 由于CSS内容比较多 ...
- css浮动--float/clear通俗讲解(转载)
本文为转载 (出处:http://www.cnblogs.com/iyangyuan/archive/2013/03/27/2983813.html) 教程开始: 首先要知道,div是块级元素,在页面 ...
- (转)经验分享:CSS浮动(float,clear)通俗讲解
文章转自:https://www.cnblogs.com/iyangyuan/archive/2013/03/27/2983813.html 很早以前就接触过CSS,但对于浮动始终非常迷惑,可能是自身 ...
- 【转】CSS浮动(float,clear)通俗讲解
作者:杨元 本文链接:http://www.cnblogs.com/iyangyuan/archive/2013/03/27/2983813.html 很早以前就接触过CSS,但对于浮动始终非常迷惑, ...
- 验分享:CSS浮动(float,clear)通俗讲解
经验分享:CSS浮动(float,clear)通俗讲解 很早以前就接触过CSS,但对于浮动始终非常迷惑,可能是自身理解能力差,也可能是没能遇到一篇通俗的教程. 前些天小菜终于搞懂了浮动的基本原理,迫不 ...
随机推荐
- 吴裕雄--天生自然 PYTHON3开发学习:输入和输出
str = input("请输入:"); print ("你输入的内容是: ", str) # 打开一个文件 f = open("/tmp/foo.t ...
- ZZJ_淘淘商城项目:day01(RESTful Web Service、SVN)
淘淘商城项目是很适合初级Java程序员练习的实战项目,本次复习是另一位张老师教授的课,内容上与之前入老师版taotao商城比较有些新东西加了进来. 因此有必要记录下那些直到现在还可供参考的技术亮点分享 ...
- 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第八天】(solr服务器搭建、搜索功能实现)
https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...
- 2019-2020-1 20199324《Linux内核原理与分析》第一周作业
1.问题:使用banner输出图形字符为什么都是大写? 2.实验二:基本概念及操作 作业:命令toilet和figlet的使用 使用如下命令安装 $ sudo apt-get update $ sud ...
- ibatis in语句参数传入方法
第一种:传入参数仅有数组 <select id="GetEmailList_Test" resultClass="EmailInfo_"& ...
- Laravel5.4 队列简单配置与使用
概述 什么是队列? 百度百科是这样说的 “队列”是在传输过程中保存数据的容器. 举几个生活中例子: * iphone手机新款发布,三里屯iphone进的新货.大家要排队买,不能说一大堆人一起冲进去,那 ...
- android仿今日头条App、多种漂亮加载效果、选择器汇总、记事本App、Kotlin开发等源码
Android精选源码 android漂亮的加载效果 android各种 选择器 汇总源码 Android仿bilibili搜索框效果 Android记事本app.分类,涂鸦.添加图片或者其他附件 仿 ...
- 2018安卓巴士开发者大会打造Android技术盛宴
2018安卓巴士开发者大会打造Android技术盛宴2018安卓巴士开发者大会将于8月25日在上海举行,作为中国最具前沿性.专业性的安卓技术会议,将邀请来自爱奇艺.阿里.饿了么等知名企业的一线工程师分 ...
- Computing Essentials_第一章习题
- 学习python-20191108(1)Mysql、Flask
一.使用pymysql模块操作MYSQL 导入pymysql模块: pip install pymysql 1.增删改 import pymysql # 定义数据库连接信息 config = { ...