11、弹性布局Flex布局

弹性布局——Flex布局

  • 容器:父元素 项目:子元素

容器属性

display:flex;

  • 规定了当前元素就是容器元素,告诉浏览器要使用flex布局

  • 会让项目在同一行显示

  • 占位置

  • 而且可以放置多个项目(默认宽度超出容器不会溢出 内容会适应盒子大小),因为有弹性

  • 设置前
    image-20240110114928932

  • 不会超出盒子大小
    image-20240110114826859

flex-direction 项目在主轴上的排列方向 (在容器上设置 四种)

  • row : 主轴方向(默认是水平方向),从左到右

  • row-reverse : 主轴横向,从右到左

image-20240110115336257

  • column: 主轴纵向,从上到下

  • column-reverse:主轴纵向,从下到上

image-20240110115522795

justify-content 项目 在主轴上的对齐方式(在容器上设置 六种)

前提是不能占满盒子,否则没有效果

  • flex-start:在主轴上的起点对齐

  • flex-end:在主轴的终点对齐

  • center:在主轴的中心对齐

image-20240110123446971

space-between:项目间距相等,第一个项目距离主轴起点和最后一个项目距离主轴终点为0

image-20240110123537674

space-evenly:项目间距都一样,包括第一个跟最后一个距离起点终点位置

image-20240110123617254

space-around:第一个项目距离起点和最后一个项目距离终点为中间项目间距的一半

image-20240110123711419

align-items项目在交叉轴的对齐方式(3种)

  • flex-start: 在交叉轴的起点对齐

  • flex-end:在交叉轴的终点对齐

  • center: 在交叉轴的中心对齐
    image-20240110123915371
    小技巧

  • 在主轴的对齐方式 与在交叉轴的对齐方式 同时使用会在水平垂直居中

    • justify-content: center;
    • align-items: center;

image-20240110124212887

flex-wrap : 设置内容是否换行

  • nowrap : 不换行
  • wrap : 换行(默认)

设置项目换行后,在交叉轴上的对齐方式

  • flex-start:在交叉轴上的起点对齐
  • flex-end:在交叉轴的终点对齐
  • center:在交叉轴的中心对齐
  • space-between
  • space-evenly:
  • space-around:

项目属性

order:默认是0,在主轴上 数值越小越靠前

align-self:设置项目交叉轴方向上的对齐方式,用于覆盖容器的align-items

image-20240110161702949

image-20240110161819650

相对于浏览器的可视化高度

<style>
	html{
	height:100%;
}
</style>

设置右侧的文字相对于同一行内的左侧图片垂直居中

flex布局

 <style>
.container {
        display: flex;
        justify-content: center;
        /* 水平居中 */
        align-items: center;
        /* 垂直居中 */
        }
</style>
</head>
<body>
    <div class="container">
        <img src="./images/adv.jpg" alt="Image">
        <p>Your TextYour TextYour TextYour TextYour Text</p>
    </div>
</body>

image-20240116112850284

行内元素vertical-align: middle;给图片添加

<style>
    img{
        vertical-align: middle;
    }
</style>
</head>
<body>
    <div class="container">
        <img src="./images/adv.jpg" alt="Image">
        <span>ahhahha</span>
    </div>
</body>
  • 13
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值