css3中的flexbox布局

这篇文章里我们将学习CSS里flexbox布局的几个最重要的概念,通过学习flexbox布局,你会发现以往遇到的所有的关于布局的问题,现在都可以轻松解决了。

我们将只关注几个核心概念,等这些核心知识掌握之后,你可以再慢慢的学习那些不重要的相关知识。

1. 容器和容器里的元素

flexbox布局的两个最重要的概念是容器(蓝色)和容器里的子元素(红色)。在本文的例子中,容器和它的子元素都是div

横向布局

为了实现flex布局,我们需要在容器的CSS里添加如下代码:

.container {
    display: flex;
}

效果如下:

211415_ZA4Q_2924812.png

对于容器里面的子元素,我们什么都不需要做。它们会自动的按横坐标一字排开。

纵向布局

在上面的演示中,缺省排列是沿着横坐标方向的,还有一个方向是纵坐标,这个坐标轴的概念在理解flex布局中非常重要。

当我们在容器的CSS里添加 flex-directioncolumn.后,子元素的排列方向就会发生变化。

.container {
    display: flex;
    flex-direction: column;
}

211445_nEKY_2924812.png
现在,子元素的排列方向是沿着纵坐标的方向了。

2. 调整子元素的对齐方式

现在我们让子元素重新横向布局,这需要将flex-direction属性的值从 column改成 row, 子元素就会重新回到横向布局。

调整子元素的对齐方式,我需要使用justify-content 和 align-items 这两个属性,它们控制着子元素的在横向和纵向两方面的定位和对齐方式。

下面我们将要使用justify-content属性让所有子元素都居中对齐:

.container {
    display: flex;
    flex-direction: row;
    justify-content: center;
}

211531_f9l4_2924812.png

使用 align-items 属性来控制子元素的竖向对齐方式:

.container {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
}

640?wx_fmt=png&tp=webp&wxfrom=5&wx_lazy=1211637_y4FR_2924812.png
下面的列表中显示了justify-content  align-items属性可以使用的属性值:

justify-content:
  • flex-start (default)

  • flex-end

  • center

  • space-between

  • space-around

align-items:
  • flex-start (default)

  • flex-end

  • center

  • baseline

  • stretch

建议大家将justify-content align-itemsflex-direction几个属性混合使用,相互配合,看看都会达到什么样的布局效果。这样你才能正确的理解flexbox布局的布局方式。

3. 子元素

最后,我们将学习针对子元素的一些应对flexbox布局的CSS属性。

比如我们想调整第一个子元素的位置,我们可以给他添加CSS属性 align-self,这个属性的属性值是和align-items是一样的用法:

.item1 {
  align-self: flex-end;
}

效果是下面这样:

是不是很神奇企且简单!

关于flexbox布局的知识远比本文介绍的这些要丰富,这总重要的几个知识点就是这些,掌握了它们,再学些其他的用法就容易多了。

转载于:https://my.oschina.net/evashuang/blog/790871

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值