实文章原名叫做 “碰到不支持 flex 的项目怎么办?”
现在差不多已经是 flex 的天下了,简单灵活,但有时还是不可避免地会接触到 IE 浏览器,比如我最近接触的 阅文作家专区 (qq.com)[1],这个就是需要兼容 IE9, 也自然不能使用 flex 布局了。不能使用 flex 怎么办(这个项目怎么这么XX,都 2021 年了还要兼容 IE)?那只能回归传统布局方式了,也就是浮动布局。
浮动 float 可以说是 CSS 布局里最为灵活的布局之一了,千万不要小瞧了浮动,有些布局只有浮动才能实现呢。下面将介绍几种常见的布局,一起看看吧
这类布局应该就是浮动最初的用意了,比如这样的
设置一个左浮动就可以了,实现如下
<div>
<strong class="float">浮</strong>
<p>动属性指定一个元素应沿其容器的左侧或右侧放置,允许文本和内联元素环绕它。该元素从网页的正常流动(文档流)中移除,尽管仍然保持部分的流动性。</p>
</div>
.float{
float: left;
/*其他样式*/
}
完整代码可访问 float-layout (codepen.io)[2]
需要注意的是,浮动元素必须放在文本的前面( HTML 结构),如果放在文本后面
<div>
<p>动属性指定一个元素应沿其容器的左侧或右侧放置,允许文本和内联元素环绕它。该元素从网页的正常流动(文档流)中移除,尽管仍然保持部分的流动性。</p>
<strong class="float">浮</strong>
</div>
那么就会变成这样
也就是说,浮动的影响范围是由浮动元素在 HTML 中的结构决定的,这一点非常重要
不过,现在很少会见到这种环绕布局了,但有些时候这种思路还是挺有用的,比如在这篇文章 CSS 实现多行文本“展开收起” (juejin.cn)[3],里面就用到了浮动的特性,实现了右下角文本环绕的效果,有兴趣的可以看看
两栏布局的特点是左边是固定尺寸,右边自动撑满剩余空间,例如
结构如下
<div class="crad">
<img class="head" src="xxx.jpg">
<p class="info">浮动属性指定一个元素应沿其容器的左侧或右侧放置,允许文本和内联元素环绕它。该元素从网页的正常流动(文档流)中移除,尽管仍然保持部分的流动性。</p>
</div>
浮动实现如下,主要是文本需要设置 overflow: hidden 。这里就不谈实现原理(BFC)了,有兴趣深究的可以查看这篇文章 CSS深入理解流体特性和BFC特性下多栏自适应布局[4]
.head{
float: left;
}
.info{
overflow: hidden;
}
如果右边是固定尺寸,比如这样的
这种情况如何处理呢?很多人可能会想到右浮动,没错,但是要注意,HTML 结构不需要改动,也就是浮动元素仍然在文本的前面
.head{
float: right;
}
值得注意的是,如果需要设置两栏的间距 margin,需要设置在浮动元素上
.head{
float: left;
margin-right: 8px;
}
完整代码可访问 float-2-cols[5]
三栏布局的特点是左右是固定尺寸,中间自动撑满剩余空间,例如
结构如下
<div>
<img class="head" src="xxx.jpg">
<div class="right">编辑</div><!--注意是在文本的前面-->
<p class="info">浮动属性指定一个元素应沿其容器的左侧或右侧放置,允许文本和内联元素环绕它。该元素从网页的正常流动(文档流)中移除,尽管仍然保持部分的流动性。</p>
</div>
注意,这里位于右侧的按钮在 HTML 结构中仍然是在文本的前方,只需要设置右浮动就行了
.head{
float: left;
}
.info{
overflow: hidden;
}
.right{
float: right;
margin-left: 8px; /*其他样式*/
}
完整代码可访问 float-3-cols (codepen.io)[6]
还有一类比较常见但是有些棘手的布局,是这样的
1.当文本比较多时,超出隐藏,标签文本在最右边2.当文本比较少时,标签文本跟随文本
示意如下
这里如何使用浮动实现呢?仔细观察,其实就是一个两栏布局
<div class="card">
<div class="right">编辑</div>
<p class="info">浮动属性指定一个元素应沿其容器的左侧或右侧放置,允许文本和内联元素环绕它。该元素从网页的正常流动(文档流)中移除,尽管仍然保持部分的流动性。一直平移直到碰到了所处的容器的边框,或者碰到另外一个浮动的元素。</p>
</div>
.info{
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
很明显现在标签文本一直位于右边,那如何实现标签文本跟随的效果呢?其实可以嵌套一个最大宽度为 100% 的容器
<div class="card">
<div class="wrap"> <!--添加一个最大宽度为100%的容器-->
<div class="right">标签</div>
<p class="info">浮动属性指定一个元素应沿其容器的左侧或右侧放置,允许文本和内联元素环绕它。该元素从网页的正常流动(文档流)中移除,尽管仍然保持部分的流动性。一直平移直到碰到了所处的容器的边框,或者碰到另外一个浮动的元素。</p>
</div>
</div>
.wrap{
display: inline-block;
max-width: 100%;
}
完整代码可访问 float-auto-text (codepen.io)[7]
如果不考虑兼容的话,width: fit-content 会是更好的选择,可以使容器保持 block 的特性,并且宽度由文本内容决定,详细可以参考这篇文章: 理解CSS3 max/min-content及fit-content等width值 [8]
.wrap{
/*display: inline-block;*/
max-width: 100%;
width: fit-content;
}
另外,如果多行文本就不适用了,可以用另一种方式实现,详细原理可以查看这篇文章 CSS 实现多行文本“展开收起” (juejin.cn)[9]
完整代码可访问float-mul-tags (codepen.io)[10]
这一部分相当于以上的扩展了,下面来看一个案例。
有时候标签的后面会有日期,会一直位于最右边,效果如下
有人可能会想到绝对定位,但是这里的日期可能不是固定的,需要自适应宽度,那如何实现呢?其实就是就是两种布局的结合
因此需要再添加一层容器,实现如下
<div class="card">
<span class="date">6-14</span>
<div class="outer-wrap">
<!--新加一层容器-->
<div class="wrap">
<div class="right">
<button class="btn">标签</button>
</div>
<p class="info">浮动属性指定一个元素应沿其容器的左侧或右侧放置,允许文本和内联元素环绕它。该元素从网页的正常流动(文档流)中移除,尽管仍然保持部分的流动性。一直平移直到碰到了所处的容器的边框,或者碰到另外一个浮动的元素。</p>
</div>
</div>
</div>
下面就是两栏布局的写法
.date{
float: right;
}
.outer-wrap{
overflow: hidden;
}
提示:如果采用 fit-content 方式,可以省去 .outer-wrap 这一层容器
实时效果如下
完整代码可访问 float-auto-text-fixed (codepen.io)[11]
上面介绍了浮动布局的几个常用案例,相信能适用于绝大部分布局,当然并不是推荐大家一定要使用浮动布局,甚至有时候布局混乱(HTML结构与视觉不一致)、实现啰嗦(嵌套层级多)等情况,但是在不兼容 flex 布局的浏览器中还是挺有用的(低于IE10),甚至还有仅仅只能使用浮动才能实现的布局(文本环绕)。这里总结如下
1.通过 BFC 实现自适应弹性布局,float + overflow2.浮动的影响范围是由浮动元素在 HTML 中的结构决定的3.通过设置最大宽度实现文本跟随效果(fit-content也可以)4.其他布局可相互组合实现5.另外这些 float 实现方式全兼容(IE6+),可以放心使用
随着 IE 地逐渐退去,有些布局也会慢慢地淡出,就像早年的 table 布局一样。但浮动布局一直在往新特性上发展,比如 Shapes 布局[12]就需要浮动做支持,另外,浮动布局也在慢慢支持逻辑属性,比如 float: inline-start 。最后,CSS 最重要的是灵活性,多一种思路总是没错的。如果觉得还不错,对你有帮助的话,欢迎点赞、收藏、转发❤❤❤
[1] 阅文作家专区 (qq.com): https://write.qq.com/
[2] float-layout (codepen.io): https://codepen.io/xboxyan/pen/RwpqWvJ
[3] CSS 实现多行文本“展开收起” (juejin.cn): https://juejin.cn/post/6963904955262435336
[4] CSS深入理解流体特性和BFC特性下多栏自适应布局: https://www.zhangxinxu.com/wordpress/2015/02/css-deep-understand-flow-bfc-column-two-auto-layout/
[5] float-2-cols: https://codepen.io/xboxyan/pen/WNpYQLB
[6] float-3-cols (codepen.io): https://codepen.io/xboxyan/pen/oNZQLWB
[7] float-auto-text (codepen.io): https://codepen.io/xboxyan/pen/poeQbYo
[8] 理解CSS3 max/min-content及fit-content等width值 : https://www.zhangxinxu.com/wordpress/2016/05/css3-width-max-contnet-min-content-fit-content/
[9] CSS 实现多行文本“展开收起” (juejin.cn): https://juejin.cn/post/6963904955262435336
[10] float-mul-tags (codepen.io): https://codepen.io/xboxyan/pen/PopWVNX
[11] float-auto-text-fixed (codepen.io): https://codepen.io/xboxyan/pen/WNpYJpN
[12] Shapes 布局: https://www.zhangxinxu.com/wordpress/2019/02/css-css3-shapes
. Float basics 浮动基础
在了解浮动之前,要先了解文档流。文档流是正式输出的流。元素在前面的元素先输出。元素写在后面的后输出。块级元素占满一行。内联元素按内容的大小占空间。且不占一行。文档流有别于浮动流。根据w3school规定,由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样。如下:
这个黄色的框在左浮动后,他下面的文字p元素就上来了。(为什么上来,因为p元素忽视浮动框的存在。P是文档流。黄色框是浮动流。)这样,他和黄色框是在同一行。文字照顾到框的存在所以向后缩进。其实<p>是也占一行的。但是它忽视黄色框的存在。按正常的文档流输出。Float以前主要是用于文字环绕图片的效果。
注释: 所有元素属性中有float或者position:abselute后 这个元素输出就是浮动流。怎么浮动看第2条。个人这么理解:浮动元素跟着浮动元素走。不考虑文档流。
1. 什么是浮动?
浮动是指浮动一个元素。当你浮动一个元素后,他就会变成一个块级元素。而且浮动时元素只能浮动到同一行的左边或者右边。
浮动的盒子脱离文档流,然后飘到最左边或者最后边。(具体见下面的解释!)
2. Where will a floated element move to? 浮动元素怎么浮动!
Floated boxes will move to the left or right until their outer edge touches the containing block edge or the outer edge of another float.
浮动的元素到达 body元素的边框
或者 其父元素的边框或者到达另外一个浮动的边框。
If there isn't enough horizontal room on the current line for the floated box, it will move downward, line by line, until a line has room for it.
译文:如果对于浮动元素来讲他所在的行没有足够的空间给他。他会移到下面的一行。下面的例子:黑盒子做float:left,黄色的做float:right。
3.当你浮动一个元素时,需要设置一个宽度。
4. 下面分析的是:一个元素在浮动元素的上面或者下面。
(重要的知识点:)★★★★★★★
第一:块级元素在上,飘的元素在下。块级元素不会受到影响。
第二:如果飘的元素在上,在他下面的元素讲会受他的影响,包围他。对于文字的话他会围绕飘的元素。但是其他块级元素,图片会伸展到其地下去。这个我从dreamweaver中已经也看到了。
看图:
如果你不想《p》元素上去了和黄色的框在同一行。可以用:清除浮动。
对p实行清除浮动。
处理这样的问题,可以对块级使用清除浮动。
规则如下:clear: left 、clear: right; clear:none;
如果你不想在浮动层下面的元素包围浮动层,你可以用清除浮动。
总结:一般元素浮动后,会空出自己的所有行。左边也好右边也好。
然后其他元素就会包围他。他需要清除自己的左边或者右边。就是表示他还是像以前那样占那么多行。比如图片占了那么多行。不让其他元素包围他。
要理解下面的现象:
上面的图片是由这个排列出来的。
Div4 因为第一行排不下去了,所以要下来。他这里有一个过程:先排到div3后面,因为排不下去了,后来就又飞到了div1的下面。因为div1高度高,把他给卡住啦。就出现了这样的情况。
基本概念:
Viewport是windows窗口的文档可见部分。
Initial containing block:是对于页面来讲的。指页面的总宽和长。
Containing box:指的是一个box。这个box带有其他元素,比如p,ul等元素。
Normal flow:文档的正常输出,如果没有float 或者position应用到这个元素。
*请认真填写需求信息,我们会在24小时内与您取得联系。