如何理解CSS中的浮动 :其实他就像乘坐扶梯一样

  只要你用过自动扶梯,你就能很快的理解CSS中的浮动(Float)。

  你肯定遇到过这样的情况:

做好了,你想用CSS浮动来调整元素间的位置关系。

  在写完代码之后,你发现浮动元素没出现在你设想的位置,而且像个磁铁一样紧紧的靠在div旁边。

  为了理解浮动这个概念,我个人曾经花费了很长的时间。有一次,我读到了一篇有关浮动的文章,觉得它说的很有道理,于是去尝试文章中的方法。但是写完代码之后,还是失败了……我也只好从头再来。

  如今我已经成功的理解了这个概念,我也想要尽我最大的努力让其他人少走弯路。

  浮动创建替代的流(flow)。这是浮动这个概念最难以理解的部分。在接触到这个概念之后,在写代码的时候,你需要将页面视为三个部分:左、中、右。对你来说,这是一个新的规则,以前你只需要调整元素的宽度或是定位,现在突然出现了流这个概念。

  事实上,浮动和乘坐扶梯差不多。通过这样的理解,下次你在使用浮动的时候,可能就不会那么纠结了。

  尊重通行规则

  元素的默认流有点像上图中的情况。一个人站在扶梯正中间,一只手还放在扶手上,这样一来,他就霸占了整个通行空间,没人能从他身边超越。这种乘坐扶梯的方式挺没有公德的。

  这个人前面的那些人,也都在这样站着,所以他也无法超越身前的那些人

  在网页开发中,如果你不使用浮动,元素就像是这些不讲公德的人一样,占据着页面的通道。

  而在使用了浮动之后,情况就会像是上面这张图一样,突然间秩序来了。

  扶梯被分成左右两个通道,人们都站在边上,当有其他人需要快速通过的时候,这些人可以从左边或是右边绕开身前的人,实现快速通行。

  没有人站在中间,因此没有人霸占着通道。

  在div中使用浮动的时候,网页就是这样。页面中出现了左边流和右边流,你可以通过浮动给元素指定他们是要待在左边还是待在右边,而那些没有使用浮动的元素,则待在左边流和右边流之间的位置。

  浮动:左边和右边

 

  浮动带来的两个新概念:左边流和右边流。

  没有使用浮动的元素,则待在文档流(normal flow)的位置上,也就是页面的中间部分。

  浮动的作用,就是在各个流中创建这些新的关系。

  如果所有人都站在扶梯的正中间,在对元素的架构进行调整时,你就会感到被处处掣肘。但是当出现了左边和右边的空间时,突然间你的选择就多了。你可以让一些人(元素)站在左边,一些站在右边,一些站在中间。

  这样一来,你就可以让元素更加易于阅读和理解。

  Clear属性

 

  我们还有一个东西没有谈到:clear属性。这个属性允许元素声明元素的哪一侧不允许其他浮动元素。

  在上图中,两个人站在电梯的左右两侧,这种站法能让后面的人更快的通行。

  我们现在假设,要让3个人站在左边,一个人站在右边。

  要想让3个元素站出现在左边流,我们可以给它们指定“clear: left”属性。但是如果这个三个元素是横向并排排列的,那么后面的元素就根本无法超越:

  “Clear: left”的作用,是告诉每一个人都站在左边,而且要排在第一个人的身后。

  clear属性最常见的用法为“clear:both”。它可以让你重设元素的流。有点像电梯上拿着行李箱的人:虽然依旧站在一侧,但是其行李箱还是堵住了中间的通道。

  这个拿着行李箱的人重设了规则。对于后来的人来说可能是个坏消息,但是如果你想要阻止其他元素通过的话,这个行李箱却是一个不错的工具。

  但是请注意,这个行李箱和文章第一张图的那个人不一样。在第一张图中,所有人都站在中间,整个扶梯上只有一个流。而这个行李箱(clear:both)虽然挡住了通道,但是整个扶梯上依然有3个流。

原文链接:https://www.sdk.cn/news/5259?utm_source=tuicool&utm_medium=referral

来源作者:Christian(编译)

时间: 2024-10-13 16:20:31

如何理解CSS中的浮动 :其实他就像乘坐扶梯一样的相关文章

深入理解CSS中的层叠上下文和层叠顺序(转)

by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.com/wordpress/?p=5115 零.世间的道理都是想通的 在这个世界上,凡事都有个先后顺序,凡物都有个论资排辈.比方说食堂排队打饭,对吧,讲求先到先得,总不可能一拥而上.再比如说话语权,老婆的话永远是对的,领导的话永远是对的. 在CSS届,也是如此.只是,一般情况下,大家歌舞升平,看不出什么差异,即所谓的众生平等.但是,当发生冲突发生纠葛的时

深入理解CSS中的margin

1.css margin可以改变容器的尺寸 元素尺寸 可视尺寸--标准盒子模型中盒子的宽度是不包括margin值的,clientWidth 占据尺寸--包括margin的宽度 outWidth不在标准之中,jquery中有相对应的方法 margin与可视尺寸 1.1使用那个与没有设定width/height的普通block水平元素 2.2只适用于水平方向尺寸 <body style="background-color:#1a2b3c"> <div style=&quo

深入理解CSS中的层叠上下文和层叠顺序

零.世间的道理都是想通的 在这个世界上,凡事都有个先后顺序,凡物都有个论资排辈.比方说食堂排队打饭,对吧,讲求先到先得,总不可能一拥而上.再比如说话语权,老婆的话永远是对的,领导的话永远是对的. 在CSS届,也是如此.只是,一般情况下,大家歌舞升平,看不出什么差异,即所谓的众生平等.但是,当发生冲突发生纠葛的时候,显然,是不可能做到完全等同的,先后顺序,身份差异就显现出来了.例如,杰克和罗斯,只能一人浮在木板上,此时,出现了冲突,结果大家都知道的.那对于CSS世界中的元素而言,所谓的“冲突”指什

深入理解css中的margin属性

转载自  http://www.cnblogs.com/zhuzhenwei918/p/6124263.html 深入理解css中的margin属性 之前我一直认为margin属性是一个非常简单的属性,但是最近做项目时遇到了一些问题,才发现margin属性还是有一些"坑"的,下面我会介绍margin的基本知识以及那些"坑".这篇博文主要分为以下几个部分: margin--基础知识 margin--在同级元素(非父子关系)之间应用 margin--在父元素和子元素之间

辛星彻底帮您解决CSS中的浮动问题

浮动,是CSS布局中必须经过的一道坎,如果不熟悉浮动,那么CSS的布局就如同空中楼阁,而谈到浮动,更多的是和div相结合,div是一个块级元素,这个我前面的博文有介绍,如果大家喜欢我的风格,可以搜索下. 下面我们进入正题,所谓浮动,可以用css的属性float来定义,比如float:left就是向左浮动,float:right就是向右浮动,我们先看一个不浮动的例子把,首先是这个html文件,这个文件我们是一直都不会动它了,它的内容如下: <html> <head> <link

辛星跟您彻底解决CSS中的浮动(下)

上面一篇博文,我们讲解了如何使用CSS中的浮动,这一篇我们来讲解一下如何清除CSS中的浮动,其实CSS中的浮动的清楚很简单,只需要使用clear属性就可以了,至于怎么用好它,很多人可能一投雾水,我在初学的时候也是经常找不着北,就好像清除浮动是个随机事件一样,当然,它不是,它的规律性很强,就让辛星来给您剖析一下这个规律把. 首先还是上面的HTML文件,它的内容如下: <html> <head> <link rel="stylesheet" type=&quo

css中的浮动以及清除浮动

对于css中的浮动问题,曾经有一段时间我是懵懵懂懂的感觉,对于float这个属性一直是似懂非懂的赶脚,对于这种让我们一直懵懵懂懂的知识点,我们就需要找个时间点,仔仔细细的去将它搞懂,从这个过程中我们也会去复习以前的知识,这是真正会让我们有所提高的一个过程,是所谓温故而知新.那么在学习的过程中也看了很多大神的博客,这里就来总结一下我个人对于float的理解; css的浮动使我们在布局的时候经常会用到的一个属性,在大量的使用过程中,我们可能只是一知半解的去使用,或者使用的时候得到了自己想要的结果就绝

【转】CSS中的浮动和清除浮动

以下转自<CSS中的浮动和清除浮动,梳理一下!> 浮动到底是什么? 浮动核心就一句话:浮动元素会脱离文档流并向左/向右浮动,直到碰到父元素或者另一个浮动元素.请默念3次! 浮动最初设计的目的并没那么多事儿,就只是用来实现文字环绕效果而已,如下所示: 文字环绕效果 但是早期的前端开发者发现:浮动的元素可以设置宽高并且可以内联排列,是介于inline和block之间的一个神奇的存在,在inline-block出来之前,浮动大行其道.直到inline-block出来后,浮动也有它自己独特的使用场景.

[转]深入理解CSS中的层叠上下文和层叠顺序

http://www.zhangxinxu.com/wordpress/2016/01/understand-css-stacking-context-order-z-index/ 零.世间的道理都是想通的 在这个世界上,凡事都有个先后顺序,凡物都有个论资排辈.比方说食堂排队打饭,对吧,讲求先到先得,总不可能一拥而上.再比如说话语权,老婆的话永远是对的,领导的话永远是对的. 在CSS届,也是如此.只是,一般情况下,大家歌舞升平,看不出什么差异,即所谓的众生平等.但是,当发生冲突发生纠葛的时候,显