(译)元素浮动的那些事儿

  原文:http://bitsofco.de/2015/how-floating-works/,作者 Ire Aderinokun 发表于 2015 年 8 月 11 日。

  尽管我们现在用浮动布局已经很少了,但是在一些特殊的需求下,它仍然是唯一可行的解决方案。在这些少见的需求中,浮动元素真正的表现形式并非像我想的那样,这使我倍受挫败。所以我决定研究一下浮动行为的规则,从而可以适当地去使用它。

浮动的规则

  float属性总共可以设置四种值:

.foo {float: left | right | inherit | none
}

  下面这些规则定义了某元素设置为以上几种浮动值时,分别该如何在其父元素乃至文档中进行定位。

  1. 浮动元素对于其父元素“不可见”。

  实际上,浮动元素会脱离其父元素。如果一个父元素仅包裹一个浮动的子元素,它会像空元素那样没有任何高度。这与其只包裹着一个绝对定位元素时的表现是非常类似的。

.parent {position: relative;padding: 10px;
}
.child {float: left 
}

  2. 向左/右浮动的元素,总是会尽可能地向其父元素的顶部及左/右部靠拢。

  一个向左或向右浮动的元素总是会想办法占据这个“最佳”位置。

  3. 如果浮动元素之前定义了一个兄弟元素,那么浮动元素会换行显示。

  尽管浮动元素会尽可能地靠近父元素的顶部,但是如果有任意的非浮动的兄弟元素位于其之前,浮动元素便会被挤下去。无论这个兄弟元素是行内元素还是块元素。这就意味着如果我们定义一个浮动元素位于一个段落之前和之后,得到的结果是完全不同的。

浮动元素位于段落元素之前

浮动元素位于段落元素之后

  一个小学生注:作者的这种说法并不严谨。她仅验证了段落时的情况。而真实情况是这样的:

如果浮动元素位于非浮动元素之前

非浮动元素的类型

浏览器类型

结果

块级元素

IE8、8+、chrome等现代浏览器

永不换行

块级元素

IE7 -

不换行,但当快级元素被显性设置宽度且宽度足够大,父容器不足以在同行排列其与浮动元素时,其会换行位于浮动元素之下。

行内级元素

IE8、8+、chrome等现代浏览器

永不换行

行内级元素

IE7 -

永不换行

如果浮动元素位于非浮动元素之后

非浮动元素的类型

浏览器类型

结果

块级元素

IE8、8+、chrome等现代浏览器

永远换行

块级元素

IE7 -

永远换行

行内级元素

IE8、8+、chrome等现代浏览器

不换行,但当父容器宽度不足以在同行排列两者时,会换行。

行内级元素

IE7 -

永远换行

  如果你想亲自实验一下,猛戳这个测试地址。

  经常有人会遇到浮动元素在IE6下换行的bug,根据上面的规则,只要把浮动元素放置在非浮动元素的前面,这个bug自然会迎刃而解了。

  4. 预先定义的浮动元素可以享受到更佳的位置。

  在HTML标签中,越靠前的浮动元素越能享受规则2中提到的“最佳”位置。例如,假如现在有一些向右浮动的元素,按照HTML中定义的顺序,第一个元素会呈现在最右侧,因为最右侧是离父元素最近的,是“最佳”位置。

<div class="container">            <div class="right">1</div><div class="right">2</div><div class="right">3</div><p>Lorem ipsum dolor sit amet, consectetur adipiscing elit...</p>
</div>

  5. 相对于尽可能地靠近父元素的左侧和右侧,浮动元素更倾向于靠近其顶部。

  当同一个方向(左/右)有多个浮动元素时,靠后者会选择远离父元素左/右侧,从而尽可能地接近父元素的顶部。这意味着多个相邻的浮动元素会尽可能地一个挨一个地排成一行展示,仅当父元素的宽度不足以包裹它们时,后定义的浮动元素才会被挤下去。

  在这个例子中,相比于元素3,元素2取得了更佳的位置。

  6. 浮动元素不应溢出其父元素。

  一个向左浮动的元素不可以超出其父元素的左侧边。

  一个向左浮动的元素不应该超出父元素的右侧边,除非父元素实在没有位置容纳下它。

浮动的清除

  clear属性常常伴随着float属性而存在。它使我们可以打破浮动元素为文档流带来的变化。我们可以把它设置为以下三个值:

.foo {clear: left | right | both 
}

  当一个元素拥有clear:left属性时,这意味着这个元素必须位于向左浮动的元素之下。如果一个元素的clear属性为both时,它必须位于任意浮动元素之下。

  如果一个元素仅仅清楚了左侧或右侧的浮动,那么向另一侧浮动的元素不会受此影响。

<div class="container">        <div class="left">1</div><div class="left">2</div><div class="left">3</div><div class="right">1</div><div class="right">2</div><div class="right">3</div><p class="clear-left">Lorem ipsum dolor sit amet, consectetur adipiscing elit...</p>
</div>

Clearfix

  我们常常对如何合适地清楚浮动有很多困惑,特别是应付那些古老的浏览器时。我用过的一个非常流行的清除浮动的方法是CSS Mojo中写的,他将下面的样式赋予浮动元素的父元素或者任意在它之后定义的元素:

.cf::after {content:"";display:table;clear:both;
}

  至于为什么这样来使用这些样式,你可以从这篇博客中找到答案。从本质上来说,这个方法也是通过创建了一个不可见的伪元素来达到清除浮动的目的。

  一个小学生注:我们之前一直用的clearfix是这样的:

.clearfix:after {content: ".";clear: both;visibility: hidden;display: block;height: 0;
}
.clearfix{ *zoom:1}

  由于IE7及以下浏览器是不支持display:table的,相比于上面作者提到的方式,虽然要多写几行样式。但胜在支持IE8-。在国内还是老老实实用这个clearfix比较好。

  更多清除浮动的方法可以查看这个demo:清除浮动的7种方法

  注意:上面的.clearfix:after一定要用单冒号,CSS3建议我们对伪元素使用双冒号,与伪类加以区分。现代浏览器识别两种写法,但是IE8仅识别单冒号。如果你写的是双冒号“.clearfix::after”,由于"*zoom:1"IE8也无法识别,这会导致你的clearfix在IE8中无效。

  (全文完)

转载于:https://www.cnblogs.com/dongtianee/p/css-float.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/296596.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

session机制和cookie机制

一、cookie机制和session机制的区别 具体来说cookie机制采用的是在客户端保持状态的方案&#xff0c;而session机制采用的是在服务器端保持状态的方案。同时我们也看到&#xff0c;由于才服务器端保持状态的方案在客户端也需要保存一个标识&#xff0c;所以session 机制可能需要…

无法定位程序输入点dxgiget_美国ABB TZIDC 智能定位器调试方法

一、ABBTZID-C 智能定位器安装及操作气路连接使用与定位器气源端口处标识的标准接口连接气源连接定位器的输出与气动执行器的气缸电气连接根据下列接线端子图以及设计要求进行相应的配线(一般只需11&#xff0c;-12&#xff0c;31&#xff0c;-32)11-12控制信号输入端子(DC4---…

这个黑科技小音箱,不用连蓝牙、一触即播

▲ 点击查看以前用蓝牙音箱&#xff0c;都要打开蓝牙找半天&#xff0c;有时还找不到对应的音箱。找到了&#xff0c;连接又很 …… 漫长 ……一句「请等待蓝牙配对」重复好几遍还没连上&#xff0c;整个人都不好了。而今天介绍的这个开物灵犀感应音箱&#xff0c;不用连蓝牙&a…

Win11运行安卓超详细教程!芜湖起飞!

一、前提Windows 11 版本号为 Build 22000.xxx 或更高版本。您的电脑硬件 BIOS/UEFI 支持虚拟化功能。二、支持本教程适用于 Windows 11 正式版和预览版&#xff0c;包括 Dev 频道、Beta 频道和 Release Preview 频道。本教程适用于搭载 Intel 和 AMD 等处理器的 Windows 11 电…

精品教程--Android实战系列源码与教程

下载源码 知识技能概要&#xff1a; 1. 此套为零基础源码与教程 2. 包括了Android应用开发所有技术 3. 配套2011QQ效果实现项目源码 4. 堪称最详细中文源码注释 ...... 详细介绍: 1. 零基础源码与教程 本套源码与教程&#xff0c;由我们具有丰富开发经验的高级程师针对需要学习…

http服务器异步响应,python – 具有异步响应的Twisted http服务器,其中请求必须等待数据变为可用或超时...

我正在尝试编写一个简单的http服务器来处理在数据结构中查找响应或超时的异步请求&#xff1a;>请求到达>时间>如果回复,请将其退回>如果超时,则返回超时消息我是新手,我想知道做异步响应的最佳方法是什么.我看了some twisted Deferred docs和callLater,但我不清楚…

linux系统将python升级到2.7.10版本

下载地址&#xff1a;https://www.python.org/ftp/python/2.7.10/Python-2.7.10.tgz下载文件到指定目录[rootoperations ~]# cd /usr/local/[rootoperations local]# wget https://www.python.org/ftp/python/2.7.10/Python-2.7.10.tgz--19:12:59-- https://www.python.org/ft…

windows系统自动化设置

为减轻windows日常维护工作量&#xff0c;可使用以下本人115网盘工具&#xff1a; 1、远程唤醒工具(远程唤醒.rar&#xff0c;绿色程序) 该工具方便运维人员在节假日及日常开机时&#xff0c;无需进入机房而实现远程开机&#xff0c;目前根据公司情况只能实现同网段机器远程唤醒…

jmeter xml 请求_Jmeter学习笔记(十六)——HTTP请求之content-type

一、HTTP请求Content-Type常见的媒体格式类型如下&#xff1a;text/html &#xff1a; HTML格式text/plain &#xff1a;纯文本格式text/xml &#xff1a; XML格式image/gif &#xff1a;gif图片格式image/jpeg &#xff1a;jpg图片格式image/png&#xff1a;png图片格式以appl…

mdx 聚合函数

聚合函数Aggregation(set_express, numeric_express), Aggregation&#xff08;http://msdn.microsoft.com/zh-cn/library/ms145524.aspx&#xff09;执行求和函数, 如果和某些其他求和函数配合的话, 会有变化. 看一个例子 SELECT { ([Measures].[Reseller Sales Amount]), ([M…

存储设备分区,格式化,挂载

blkid:查看分区UUID以及类型[rootlocalhost ~]# blkid /dev/sda2: UUID"8e6e21f9-c296-4493-986c-41204c8c4bdb" TYPE"ext4" /dev/sda3: UUID"d36c4b0d-1942-48b2-8d17-fbbd2df506bc" TYPE"ext4"分区完成之后&#xff0c;运行partpro…

被小学数学题套路到哭!这些“逆天”题目,谁做谁知道…

全世界只有3.14 % 的人关注了爆炸吧知识看着孩子的作业题&#xff0c;有多少爸爸妈妈感叹着&#xff0c;幸亏自己毕业早&#xff0c;要不然小学都不能毕业&#xff01;这不&#xff0c;最近一道简单的小学数学题&#xff0c;又刷爆了家长们的朋友圈。一起往下看。算一算图中的这…

ASP.NET性能优化之构建自定义文件缓存

ASP.NET的输出缓存&#xff08;即静态HTML&#xff09;在.NET4.0前一直是基于内存的。这意味着如果我们的站点含有大量的缓存&#xff0c;则很容易消耗掉本机内存。现在&#xff0c;借助于.NET4.0中的OutputCacheProvider&#xff0c;我们可以有多种选择创建自己的缓存。如&…

《Redis核心技术与实战》学习总结(1)

【Redis】| 总结/Edison Zhou0写在开头作为Key/Value键值数据库&#xff0c;Redis的应用非常广泛。在之前多年的工作生涯中&#xff0c;我也只是关注了零散的技术点&#xff0c;没有对Redis建立起一套整体观&#xff0c;但只有建立了系统整体观&#xff0c;才能更好地定位问题和…

云管边端架构图_中移物联网布局构建“云-管-端”全方位体系架构

随着物联网的步伐&#xff0c;国内三大运营商纷纷成立自己的物联网团队&#xff0c;而在物联网连接管理平台方面&#xff0c;电信与爱立信合作&#xff0c;联通与Jasper合作&#xff0c;移动则采取自主研发的OneLink平台。在此环境下&#xff0c;全球物联网管理平台逐渐形成四分…

c++学习笔记九

程序文件和预处理指令1 程序文件头文件:类型定义和其他用于程序中一个或多个源文件的代码 后缀名为&#xff1a;.h源文件&#xff1a;要编译成机器指令的代码 后缀名为&#xff1a;.cpp .c .cxx引入头文件 代码格式如下:#include<iostream>名称的作用域程序文件的连链…

SIP for android

SIP for android 会话发起协议 Android提供了一个支持会话发起协议&#xff08;SIP&#xff09;的API&#xff0c;这可以让你添加基于SIP的网络电话功能到你的应用程序。Android包括一个完整的 SIP协议栈和集成的呼叫管理服务&#xff0c;让应用轻松无需管理会话和传输层的沟…

饿了么翻车,美团被质疑,马云也赔了40亿,这项技术为什么让人害怕?

全世界只有3.14 % 的人关注了爆炸吧知识人类还没用力AI可能就倒下了8日&#xff0c;一篇《外卖骑手&#xff0c;困在系统里》的文章刷爆了朋友圈。看过的人多半都不好受&#xff0c;除了作为社畜感叹生活不易外&#xff0c;就是感叹外卖系统的AI算法对人类的裹挟是那么的残酷。…

如何强制 .NET 程序以 管理员模式 运行 ?

咨询区 Gold&#xff1a;我有一个 winform 程序部署客户的PC机上&#xff0c;请问我如何通过编码的形式强制让程序以管理员模式运行&#xff1f;回答区 Gaspa79&#xff1a;如果你用的是 Visual Studio 2019&#xff0c;可以通过工具去配置&#xff0c;右键 项目 -> 新建项 …

bitmap 转byte[]后读取_闲谈redis的bitmap

bitmap的原理bitmap就是通过最小的单位bit(8bit 1b 0.001kb)来进行0或者1的设置&#xff0c;表示某个元素对应的值或者状态。一个bit的值&#xff0c;或者是0&#xff0c;或者是1&#xff1b;也就是说一个bit能存储的最多信息是2。优点基于最小的单位bit进行存储&#xff0c;…