zoukankan      html  css  js  c++  java
  • 关于 圣杯布局(双飞翼布局)的一些想法

    网络上讲圣杯布局(双飞翼布局)的文章一搜一堆,比如以下:

    css布局之圣杯布局和双飞翼布局

    但是讲原理的没几个。

    我自己一开始没想通为什么为浮动元素设置 margin-left: -100% 后移动到了上一行。

    直到我看到了下面的文章:

    浅谈margin负值

     


     

    但是我想记录下来的是为什么要这么复杂的去实现 “三栏布局,左右定宽,中间自适应”呢?

    这是个疑问,暂且放在这里,什么时候我想通了,再来填坑。

    或者有大神来给我指条明路啊。

    以下是我自己的实现方式,共有三种。

     

    方法1:浮动实现

    html:

    此处left_box和right_box必须要写在middel_box前面。

    因为浮动布局只会对它下面的盒子的布局产生影响。

    我们通常需要清除浮动来避免浮动给下面的盒子布局产生影响,这里反其道而行,利用了这一点。

    <div class="box2">
      <div class="left_box">123</div>
      <div class="right_box">abc</div>
      <div class="middle_box">middle</div>
    </div>

    css:

    .box2 {
        height: 100px;
        margin: 50px auto;
        border: 2px solid yellow;
    }
    
    .box2 .middle_box {
        height: 100%;
        background-color: pink;
        margin: 0 100px;
    }
    
    .box2 .left_box {
        float: left;
        width: 50px;
        height: 100%;
        background-color: orange;
    }
    
    .box2 .right_box {
        float: right;
        width: 50px;
        height: 100%;
        background-color: skyblue;
    }

    方法2: 定位实现

    html:

    与方法2相同,只不过 middle_box的位置没有限制,可以写在left_box 和 right_box 前面,使middel_box可以优先渲染。

    <div class="box3">
            <div class="left_box">123</div>
            <div class="right_box">abc</div>
            <div class="middle_box">middle</div>
    </div>

    css:

    .box3 {
        position: relative;
        height: 100px;
        margin: 50px auto;
        border: 2px solid yellow;
    }
    
    .box3 .middle_box {
        height: 100%;
        background-color: pink;
        margin: 0 100px;
    }
    
    .box3 .left_box,
    .box3 .right_box {
        position: absolute;
        width: 50px;
        height: 100%;
        background-color: orange;
    }
    
    .box3 .right_box {
        right: 0;
        background-color: skyblue;
    }

    实现效果:

    原理:

    先不管两侧的盒子(就当不存在)

    1. 用普通的流布局做出中间的盒子 middle_box,不给width值,只设置两侧的margin值(padding值也可以)。

    让middle_box能随父盒子拉伸。

    2. 用定位或浮动把两侧的盒子 left_box 和 right_box 定位在 middle_box 两边。

     补充:

    方法3: flex布局

     HTML:

    <div class="box1">
         <div class="left_box">123</div>
         <div class="middle_box">middle</div>
         <div class="right_box">abc</div>
    </div>

    CSS:

    .box1 {
        display: flex;
        height: 100px;
        border: 2px solid yellow;
    }
    
    .box1 .middle_box {
        flex: 1;
        background-color: pink;
    }
    
    .box1 .left_box {
        width: 50px;
        background-color: orange;
    }
    
    .box1 .right_box {
        width: 50px;
        background-color: skyblue;
    }

     

     

  • 相关阅读:
    CSS浏览器兼容----IE的定制CSS样式
    CSS浏览器兼容---判断IE版本的HTM语句
    单链表操作1
    数学建模1
    浏览器内核学习笔记二
    浏览器内核学习笔记一
    网页使用特殊字体
    SQL Server 2008 R2没有卸载干净
    RadioButtonFor绑定值
    SVN 服务启动报错 0x8007042a
  • 原文地址:https://www.cnblogs.com/jeacy/p/13086824.html
Copyright © 2011-2022 走看看