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


    基于 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 Bintitle>
      <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">centerdiv>
      <div class="left">leftdiv>
      <div class="right">rightdiv>
    div>
    body>
    html>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39

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

  • 相关阅读:
    docker 部署mysql主从复制
    python写一个文本处理器
    SQL Server实战四:查询数据库的数据
    申请软件著作权的流程
    pytorch应用于MNIST手写字体识别
    400电话申请办理:为企业提供高效沟通的必备工具
    1、Vue 环境搭建
    项目分享20
    springbean的生命周期
    StringBuilder 和 StringBuffer:Java字符串处理的利器
  • 原文地址:https://blog.csdn.net/huaqi_/article/details/126107159