怎么掌握CSS工具Flexbox
本篇内容主要讲解"怎么掌握CSS工具Flexbox",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么掌握CSS工具Flexbox"吧!
随着CSS网格布局的引入,你可能会问flexbox布局是否真的还有必要。虽然它们所能做的事情有一些重叠,但其各自在CSS布局中有着非常特别的目的。一般来说,flexbox在一维场景(比如,一串类似的元素)下有最佳应用,而网格是二维场景下理想的布局方案(例如整个页面的元素)。
即便如此,flexbox仍可以用于整个页面的布局,这样它能为那些还不支持网格布局的浏览器提供合适的兼容处理。(必须承认,网格布局正在大多数现代浏览器中快速得到支持,不过对flexbox的支持仍然更为广泛,所以如果你想让你的布局在稍微老旧的浏览器中也生效,使用flexbox作为网格布局的降级方案是很容易的)。
使用Flexbox的好处
flexbox的一些好处是:
页面元素能被任意方向地放置(靠左、靠右、从上往下甚至从下往上)
布局内容的可视顺序能够被反转或重排
元素大小能"弹性"适应可用空间,并根据容器或者兄弟元素进行相应地对齐
能轻松实现等列宽布局(与每一列里面的内容无关)
为了阐述其多样的属性和可能性,让我们假设下面有这样的布局用例:
header content here main content here
首先,是把元素一起放进.main里,比如,
让flexbox来救场吧。
让我们Flex
flexbox的要点是出现在display属性上的flex值,它需要被设置在容器元素上。如此设置会让它的子元素变成"弹性项目(flex item)"。这些弹性项目拥有一些易于使用的默认属性。比如,它们被紧挨着放置,那些没有特别指明宽度的元素自动占满了剩余的空间。
因此,如果你给.main设置了display:flex,它的子元素.content就被自动挤在
.main { display: flex;}
请查看下面的例子,包含了所有的细节
项的顺序:Flebox的****order****属性
另外一个flexbox的能力,是能够轻松改变元素的显示顺序。让我们假设你为一个客户制作了上面的布局,而她现在想要.content出现在
通常,你需要深入到HTML源码中去,在那里改变元素的顺序。而有了Flexbox,你可以完全使用CSS完成这项任务。只需把.content的order属性设置为-1,那么这一列就会出现在前面,这本例就是最左边。
.main { display: flex;} .content { order: -1;}
本例中,你不需要改变其他列的order。例子在 flexbox-demo-2 。
如果你倾向于显式地为每一列指定order,你可以将.content的order设为1,把
HTML源码独立于CSS的Flexbox样式
但你的客户并不满足。她想让