如何实现侧边两栏宽度固定,中间栏宽度自适应的布局?——双飞翼布局、圣杯(Holy Grails)布局

勇气也许不能所向披靡,但胆怯根本无济于事。

希望你永远有勇气从头再来。

14690f44d59e4abfad28a425c8a9d6bf.jpeg

引用——圣杯(Holy Grails)布局&双飞翼布局

        圣杯布局的出现是来自由 Matthew Levine 在 2006 年写的一篇文章 

        《In Search of the Holy Grail》,

        国内最早是淘宝UED的工程师(玉伯)对圣杯布局改进并传播开来,国内叫法是双飞翼布局 。

        双飞翼布局是针对圣杯局部优化的解决方案。主要是优化了圣杯布局中开启定位的问题。

da08f9d1df4b92b2d21c4a96cd475d35.png

 

        圣杯布局和双飞翼布局达到的效果基本相同,

        均是三栏布局,侧边两栏宽度固定,中间栏宽度自适应。

        主要的不同之处就是在防止中间部分被覆盖时,采取的解决办法不一样

        圣杯布局是在父元素上设置了padding-left和padding-right,在给左右两边的内容设置position为relative,通过左移和右移来使得左右两边的内容得以很好的展现,

        而双飞翼则是在center这个div中再加了一个div来放置内容,在给这个新的div设置margin-left和margin-right 。

6e4bb581145d4a5e87b61b8b24bbad5f.jpeg

 浮动实现(兼容性好)

 1.圣杯布局c1c6b6b5c2df48af8b11cef28ef2d37a.png

 

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>圣杯布局</title>
    <style type="text/css">
        body {
            min-width: 550px;
        }
        #header {
            text-align: center;
            background-color: #666;
        }

        #container {
            padding-left: 200px;
            padding-right: 150px;
        }
        #container .column {
            float: left;
            text-align: center;
        }

        #center {
            background-color: #D6D6D6;
            width: 100%;
        }
        #left {
            position: relative;
            background-color: #77BBDD;
            width: 200px;
            margin-left: -100%;
            right: 200px;
        }
        #right {
            background-color: #FF6633;
            width: 150px;
            margin-right: -150px;
        }

        #footer {
            background-color: #666;
        }

        /* 手写 clearfix */
        .clearfix:after {
            content: '';
            display: table;
            clear: both;
        }
    </style>
</head>
<body>
    <div id="header">#header</div>
    <div id="container" class="clearfix">
        <div id="center" class="column">#center</div>
        <div id="left" class="column">#left</div>
        <div id="right" class="column">#right</div>
    </div>
    <div id="footer">#footer</div>
</body>
</html>

(1)container设置padding属性,使width100%的center收缩,空出左右两栏的位置

(2)center、left、right等元素浮动起来,container没有设置高度,高度由内容撑开,所以container需要清除浮动

(3)给left元素设置margin-left:-100%; 它将向左移动父元素宽度的100%于是覆盖到center上

cd5e8375d20b475989373008cea713f8.png

再给它设置相对定位,right:200px;使其继续向左移动,移动到合适位置。

60665001bca24b6a8ec94c635cefe32d.png

 (4)给right元素设置margin-right:-150px;使其宽度被忽略,视为0,将其放置在center后。

1485d689fa0841de8e937f95b1cbbe9a.png

手写清除浮动

/* 手写 clearfix */
.clearfix:after {
     content: '';
    display: table;
    clear: both;
}

2.双飞翼布局

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>双飞翼布局</title>
    <style type="text/css">
        body {
            min-width: 550px;
        }
        .column {
            float: left;
        }

        #center {
            width: 100%;
            height: 200px;
            background-color: #D6D6D6;
        }
        #center-wrap {
            margin: 0 200px 0 200px;
        }

        #left {
            width: 200px;
            height: 200px;
            background-color: #77BBDD;
            margin-left: -100%;
        }
        #right {
            width: 200px;
            height: 200px;
            background-color: #FF6633;
            margin-left: -200px;
        }
    </style>
</head>
<body>
    <div id="center" class="column">
        <div id="center-wrap">
            center
        </div>
    </div>
    <div id="left" class="column">
        left
    </div>
    <div id="right" class="column">
        right
    </div>
</body>
</html>

(1)给center-wrap设置margin,空出左右两栏的位置

c494736b04214ddc9c26be97ecda9c93.png

(2)给left元素设置margin-left: -100%; 使其移动到左侧

5d008cae08e14c9e982a09d15a6633a2.png

 (3)给right设置margin-left:-200px; 使其移动到右侧

a83ff14f2eb24b7aaf4dcbbfca7683ed.png

 

flex实现(实现简单)

2c0c52ae99774699aea8b828c72d929e.png

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>flex实现圣杯布局</title>
    <style type="text/css">
        body {
            min-width: 550px;
        }
        #header {
            text-align: center;
            background-color: #666;
        }

        #container {
            display: flex;
        }
        #container .column {
            text-align: center;
        }

        #center {
            flex: 1;
            background-color: #D6D6D6;
        }
        #left {
            background-color: #77BBDD;
            width: 200px;
        }
        #right {
            background-color: #FF6633;
            width: 150px;
        }

        #footer {
            background-color: #666;
        }

    </style>
</head>
<body>
    <div id="header">#header</div>
    <div id="container">
        <div id="left" class="column">#left</div>
        <div id="center" class="column">#center</div>
        <div id="right" class="column">#right</div>
    </div>
    <div id="footer">#footer</div>
</body>
</html>

 

 

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值