如何理解CSS中的浮动 :其实他就像乘坐扶梯一样
|
只要你用过自动扶梯,你就能很快的理解CSS中的浮动(Float)。 你肯定遇到过这样的情况: 做好了,你想用CSS浮动来调整元素间的位置关系。
在写完代码之后,你发现浮动元素没出现在你设想的位置,而且像个磁铁一样紧紧的靠在div旁边。 为了理解浮动这个概念,我个人曾经花费了很长的时间。有一次,我读到了一篇有关浮动的文章,觉得它说的很有道理,于是去尝试文章中的方法。但是写完代码之后,还是失败了……我也只好从头再来。 如今我已经成功的理解了这个概念,我也想要尽我最大的努力让其他人少走弯路。 浮动创建替代的流(flow)。这是浮动这个概念最难以理解的部分。在接触到这个概念之后,在写代码的时候,你需要将页面视为三个部分:左、中、右。对你来说,这是一个新的规则,以前你只需要调整元素的宽度或是定位,现在突然出现了流这个概念。 事实上,浮动和乘坐扶梯差不多。通过这样的理解,下次你在使用浮动的时候,可能就不会那么纠结了。 尊重通行规则
元素的默认流有点像上图中的情况。一个人站在扶梯正中间,一只手还放在扶手上,这样一来,他就霸占了整个通行空间,没人能从他身边超越。这种乘坐扶梯的方式挺没有公德的。 这个人前面的那些人,也都在这样站着,所以他也无法超越身前的那些人 在网页开发中,如果你不使用浮动,元素就像是这些不讲公德的人一样,占据着页面的通道。
而在使用了浮动之后,情况就会像是上面这张图一样,突然间秩序来了。 扶梯被分成左右两个通道,人们都站在边上,当有其他人需要快速通过的时候,这些人可以从左边或是右边绕开身前的人,实现快速通行。 没有人站在中间,因此没有人霸占着通道。 在div中使用浮动的时候,网页就是这样。页面中出现了左边流和右边流,你可以通过浮动给元素指定他们是要待在左边还是待在右边,而那些没有使用浮动的元素,则待在左边流和右边流之间的位置。 浮动:左边和右边
浮动带来的两个新概念:左边流和右边流。
没有使用浮动的元素,则待在文档流(normal flow)的位置上,也就是页面的中间部分。
浮动的作用,就是在各个流中创建这些新的关系。 如果所有人都站在扶梯的正中间,在对元素的架构进行调整时,你就会感到被处处掣肘。但是当出现了左边和右边的空间时,突然间你的选择就多了。你可以让一些人(元素)站在左边,一些站在右边,一些站在中间。 这样一来,你就可以让元素更加易于阅读和理解。 Clear属性
我们还有一个东西没有谈到:clear属性。这个属性允许元素声明元素的哪一侧不允许其他浮动元素。
在上图中,两个人站在电梯的左右两侧,这种站法能让后面的人更快的通行。 我们现在假设,要让3个人站在左边,一个人站在右边。 要想让3个元素站出现在左边流,我们可以给它们指定“clear: left”属性。但是如果这个三个元素是横向并排排列的,那么后面的元素就根本无法超越:
“Clear: left”的作用,是告诉每一个人都站在左边,而且要排在第一个人的身后。 clear属性最常见的用法为“clear:both”。它可以让你重设元素的流。有点像电梯上拿着行李箱的人:虽然依旧站在一侧,但是其行李箱还是堵住了中间的通道。
这个拿着行李箱的人重设了规则。对于后来的人来说可能是个坏消息,但是如果你想要阻止其他元素通过的话,这个行李箱却是一个不错的工具。 但是请注意,这个行李箱和文章第一张图的那个人不一样。在第一张图中,所有人都站在中间,整个扶梯上只有一个流。而这个行李箱(clear:both)虽然挡住了通道,但是整个扶梯上依然有3个流。 来源作者:Christian(编译)
|
如何理解CSS中的浮动 :其实他就像乘坐扶梯一样的更多相关文章
- 深入理解CSS中的层叠上下文和层叠顺序(转)
by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.com/wordpress/?p=5115 零.世间的道 ...
- 深入理解css中的margin属性
深入理解css中的margin属性 之前我一直认为margin属性是一个非常简单的属性,但是最近做项目时遇到了一些问题,才发现margin属性还是有一些“坑”的,下面我会介绍margin的基本知识以及 ...
- css中的浮动以及清除浮动
对于css中的浮动问题,曾经有一段时间我是懵懵懂懂的感觉,对于float这个属性一直是似懂非懂的赶脚,对于这种让我们一直懵懵懂懂的知识点,我们就需要找个时间点,仔仔细细的去将它搞懂,从这个过程中我们也 ...
- 深入理解CSS中的层叠上下文和层叠顺序
零.世间的道理都是想通的 在这个世界上,凡事都有个先后顺序,凡物都有个论资排辈.比方说食堂排队打饭,对吧,讲求先到先得,总不可能一拥而上.再比如说话语权,老婆的话永远是对的,领导的话永远是对的. 在C ...
- 【转】CSS中的浮动和清除浮动
以下转自<CSS中的浮动和清除浮动,梳理一下!> 浮动到底是什么? 浮动核心就一句话:浮动元素会脱离文档流并向左/向右浮动,直到碰到父元素或者另一个浮动元素.请默念3次! 浮动最初设计的目 ...
- [转]深入理解CSS中的层叠上下文和层叠顺序
http://www.zhangxinxu.com/wordpress/2016/01/understand-css-stacking-context-order-z-index/ 零.世间的道理都是 ...
- 深入理解CSS中的margin
1.css margin可以改变容器的尺寸 元素尺寸 可视尺寸--标准盒子模型中盒子的宽度是不包括margin值的,clientWidth 占据尺寸--包括margin的宽度 outWidth不在标准 ...
- CSS中的浮动和定位
在了解CSS中的浮动和定位之前有必要先了解清楚标准流和脱离标准流的特性 标准流的默认特性 1.分行.块级元素,并且能够dispay转换. 2.块级元素(block):默认独占一行,不能并列显示,能够设 ...
- 深入理解css中position属性及z-index属性
深入理解css中position属性及z-index属性 在网页设计中,position属性的使用是非常重要的.有时如果不能认识清楚这个属性,将会给我们带来很多意想不到的困难. position属性共 ...
随机推荐
- hdu 5997 rausen loves cakes(线段数合并+启发式修改)
题目链接:hdu 5997 rausen loves cakes 题意: 给你n个点,每个点有一个颜色,现在有两个操作,第一个操作,将颜色x改为颜色y,第二个操作,询问[x,y]区间有多少颜色段(颜色 ...
- Vue.js教程
https://aotu.io/notes/2016/10/13/vue2/?o2src=juejin&o2layout=compat
- [kuangbin带你飞]专题六 最小生成树 POJ 2421 Constructing Roads
给一个n个点的完全图 再给你m条道路已经修好 问你还需要修多长的路才能让所有村子互通 将给的m个点的路重新加权值为零的边到边集里 然后求最小生成树 #include<cstdio> #in ...
- 在ueditor编辑器的光标停留处插入内容
业务场景: 首先在ueditor编辑器中插入一段文本,然后我想在文本的某个位置(光标停留处)插入一个字符串,这个字符串是从页面的其他地方选择得来的. 注意,当我们点击ueditor编辑器以外的地方,编 ...
- [M]带属性块参照的转换
有一张表格,表格的每一行都由带有属性的块参照组成,如图: 魔法表格不能直接识别有块参照组成的表格,需要使用 EXPLODE 命令将块参照分解,但多分解带有属性的块只能得到属性的定义 这是就需要使用 B ...
- sealed的作用
sealed 修饰符表示密封 用于类时,表示该类不能再被继承,不能和 abstract 同时使用,因为这两个修饰符在含义上互相排斥 用于方法和属性时,表示该方法或属性不能再被重写,必须和 overri ...
- WordPress网站加速优化,一键免费使用七牛CDN插件
利用wordpress搭建网站是个人建站的主流方案,我曾分享过wordpress网站加速优化必做的十件事,帮助了不少个人站长.今天介绍帮助wordpress网站提升速度至少10倍的免费CDN加速插件: ...
- Python基础知识学习_Day1
1,python介绍 诞生于1989年圣诞节,目前越来越受到业界认可.应用领域十分广泛 云计算: 云计算最火的语言, 典型应用OpenStack WEB开发: 众多优秀的WEB框架,众多大型网站均为P ...
- tomcat解压版安装(摘自网络)
配置Tomcat[解压版] 选择解压版的Tomcat的理由是可以让我们使用多个Tomcat,但是配置上就会出现一些问题,需要我们手动进行更改配置.我的Tomcat版本是:apache-tomcat-6 ...
- 疯狂java讲义--笔记
第一章.Java语言概述与开发环境 什么是软件:一系列按照特定顺序组织的计算机数据和指令的集合: 交互方式:两种 GUI(Graphical User Interface) 图像界面 .CLI (Co ...






