基于 flex 布局实现的三栏布局

本文探讨了如何使用 CSS flex 布局创建三栏布局,重点解释了为何将 `div.center` 作为首个子元素的原因,以及在没有明确设置 `width: 100%` 的情况下,`div.center` 仍能自动撑开的机制。通过 `order` 和 `flex` 属性调整元素顺序和空间分配,并分析了块级元素默认的宽度行为。推荐阅读张鑫旭的《CSS 世界》了解更多 CSS 知识。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基于 flex 布局实现的三栏布局

我愿称之为史上最简单(实现简单、理解简单)的三栏实现。

为什么将 div.center 作为 div.container 的首个子元素?

为了其优先加载,div.center 中一般都是存放页面的主要内容。

主要功臣是属性 order、flex。

order 属性可以自定义元素的渲染位置顺序。

flex: 1; 使该元素占据元素的剩余空间。

div.container 也没有声明 width: 100% 那为什么 div.center 会自动撑开呢?

类似 div 这种块级元素,默认 width: auto;

对于普通块级元素,其具有充分利用可用空间的特性,即 fill-available。

此时,width: 100% 属于吃力不讨好的声明。

众所周知,默认:box-sizing: content-box。此时 width 直接作用于 content-box,若声明 width: 100%,那么 padding、boder、margin 怎么办?

当然可以再声明 box-sizing: border-box,对于此,其他坏处暂且不提,同样的效果,多两行代码。

更多 CSS 相关知识见 张鑫旭《CSS 世界》。

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width">
  <title>JS Bin</title>
  <style>
    .container {
      display: flex;
    }

  .left {
    order: 1;
    width: 200px;
    height: 300px;
    background-color: rgba(100, 0, 0, .6);
  }

  .center {
    order: 2;
    flex: 1;
  }  

  .right {
    order: 3;
    width: 200px;
    height: 300px;
    background-color: rgba(100, 0, 100, .6);
  }
  </style>
</head>
<body>
<div class="container">
  <div class="center">center</div>
  <div class="left">left</div>
  <div class="right">right</div>
</div>
</body>
</html>

基于 flex 布局实现的三栏布局 - jsbin

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值