圣杯布局与双飞翼布局

圣杯布局和双飞翼布局都是实现的三栏布局,两边的盒子宽度固定,中间盒子自适应,也就是我们常说的固比固布局。它们实现的效果是一样的,差别在于其实现的思想。

圣杯布局的出现是来自于a list part上的一篇文章In Search of the Holy Grail。比起双飞翼布局,它的起源不是源于对页面的形象表达。在西方,圣杯是表达“渴求之物”的意思。而双飞翼布局,源与淘宝的UED。

通过缩放页面就可以发现,随着页面的宽度的变化,这三栏布局是中间盒子优先渲染,两边的盒子框子固定不变,即使页面宽度变小,也不影响我们的浏览。
注意:当缩放页面的时候,宽度不能小于700PX,为了安全起见,最好还是给body加一个最小宽度!

整体HTML结构代码如下:

<header><h4>Header内容区h4>header>
    <div class="container">
        <div class="middle"><h4>中间弹性区h4>div>
        <div class="left"><h4>左边栏h4>div>
        <div class="right"><h4>右边栏h4>div>
    div>
<footer><h4>Footer内容区h4>footer>

注意:上述代码,父元素的的三栏务必先写中间盒子。因为中间盒子是要被优先渲染,并且设置其自适应,也就是width:100%。

每个盒子的CSS样式如下:

header{width: 100%;height: 40px;background-color: darkseagreen;}
.container{ height:200px;overflow:hidden;}
.middle{width: 100%;height: 200px; background-color: deeppink;float:left;}
.left{ width: 200px;height: 200px;background-color: blue;float:left;}
.right{width: 200px;height: 200px;background-color: darkorchid;float:left;}
footer{width: 100%; height: 30px;background-color: darkslategray;}

样式如下:
圣杯布局与双飞翼布局_第1张图片

三栏并没有在父元素的一行显示,就是因为中间盒子给了百分之百的宽度,左右两个盒子才会被挤下来。
如果中间盒子不是100%的宽度,按照文档流,左边的盒子一定会在中间盒子的后面显示,接着显示右边的盒子。但是现在中间盒子是满屏了的,所以左右两个盒子被挤到下一行显示。

1)让左边的盒子上去,设置其左边距为负的中间盒子的宽度,也就是.left {margin-left:-100%;}。这样左盒子才可以往最左边移动。
2)让右边的盒子上去,设置其左边距为负的自己的宽度,也就是.right {margin-left:-200px;}。这样右盒子才可以在一行的最右边显示出自己。

目前硬性的实现了固比固布局。但中间盒子是自适应的宽度,所以中间盒子里的内容会被左右盒子给压住一部分。比如现在我给中间盒子加很多的内容,大家看看效果图:

圣杯布局与双飞翼布局_第2张图片

利用父级元素设置左右内边距的值,把父级的三个子盒子往中间挤。代码如下:.container{ padding: 0 200px;} 这里的200px是左右盒子的宽度。

圣杯布局与双飞翼布局_第3张图片

左右两边的内边距是有了,但是中间盒子上的内容还是被压着。
给左右两个盒子加一个定位,加了定位之后左右两个盒子就可以设置left和right值。

代码如下:
.left{ position: relative; left: -200px;}
.right{position: relative;right: -210px;}

圣杯布局与双飞翼布局_第4张图片

圣杯布局终于搞定了,也实现了我们要的效果,左右侧的盒子固定,中间盒子自适应,而且中间盒子的内容完全不受影响。

圣杯布局和双飞翼布局解决的问题是一样的,都是两边定宽,中间自适应的三栏布局,中间栏要在放在文档流前面以优先渲染。

两种方法基本思路都相同:
1)首先让中间盒子 100% 宽度占满同一高度的空间
2)在左右两个盒子被挤出中间盒子所在区域时,使用 margin-left 的负值将左右两个盒子拉回与中间盒子同一高度的空间。
3)接下来进行一些调整避免中间盒子的内容被左右盒子遮挡。

主要区别在于如何使中间盒子的内容不被左右盒子遮挡:
圣杯布局的方法:设置父盒子的 padding 值为左右盒子留出空位,再利用相对布局对左右盒子调整位置占据 padding 出来的空位;
双飞翼布局的方法:在中间盒子里再增加一个子盒子,直接设置这个子盒子的 margin 值来让出空位,而不用再调整左右盒子。

简单说起来就是双飞翼布局比圣杯布局多创建了一个div,但不用相对布局了,少设置几个属性。

你可能感兴趣的:(前端开发)