稍微了解前端的人都知道,圣杯布局和双飞翼布局是前端面试时必问的问题,由于它既能体现你懂HTML结构又能体现出你对DIV+CSS布局的掌握,毕竟咱们学习CSS主要就是为了更好地布局带来最好的用户体验嘛~前端
事实上,圣杯布局其实和双飞翼布局是一回事。它们实现的都是三栏布局,两边的盒子宽度固定,中间盒子自适应,也就是咱们常说的固比固布局。它们实现的效果是同样的,差异在于其实现的思想。面试
圣杯布局的出现是来自于a list part上的一篇文章In Search of the Holy Grail。比起双飞翼布局,它的起源不是源于对页面的形象表达。在西方,圣杯是表达“渴求之物”的意思。而双飞翼布局则是源于淘宝的UED,能够说是灵感来自于页面渲染。一块儿来看看这两种布局的区别在哪:安全
1、双飞翼布局
能够看到,咱们在main里面又加了一个内容层。若是知道盒子模型,就知道咱们是不能直接给main添加margin属性,由于咱们已经设置了width:100%,再设置margin的话就会超过窗口的宽度,因此咱们再创造一个内容层,将全部要显示的内容放到main-content中,给main-content设置margin就能够了。布局
经过缩放页面就能够发现,随着页面的宽度的变化,这三栏布局是中间盒子优先渲染,两边的盒子框子固定不变,即便页面宽度变小,也不影响咱们的浏览。若是你有了那么一点理解之后,咱们来看看圣杯布局的实现:学习
2、双飞翼布局
<header><h4>Header内容区</h4></header>
spa
<div class="middle"><h4>中间弹性区</h4>
code
<div class="left"><h4>左边栏</h4></div>
cdn
<div class="right"><h4>右边栏</h4></div>
blog
</div>
文档
<footer><h4>Footer内容区</h4></footer>
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;}
你们能够看到,三栏并无在父元素的一行显示,就是由于中间盒子咱们给了百分之百的宽度。全部左右两个盒子才会被挤下来。
那么如何让它们呈现出一行三列的效果呢?那就要让左边的盒子要到中间盒子的最左边,右边的盒子到中间盒子的最右边。换个想法,若是中间盒子不是100%的宽度,那么按照文档流,左边的盒子必定会在中间盒子的后面显示,接着显示右边的盒子。可是如今中间盒子是满屏了的,因此左右两个盒子被挤到下一行显示。咱们要作到的是让左右两个盒子都上去。此时,CSS的负边距(negative margin)该上阵了。
须要设置其左边距为负的中间盒子的宽度,也就是.left {margin-left:-100%;}。这样左盒子才能够往最左边移动。
须要设置其左边距为负的本身的宽度,也就是.right {margin-left:-200px;}。这样右盒子才能够在一行的最右边显示出本身。
首先:利用父级元素设置左右内边距的值,把父级的三个子盒子往中间挤。
代码以下:
.container{ padding: 0 200px;} 这里的200px是左右盒子的宽度。
效果以下:
咱们能够看到,左右两边的内边距是有了,可是中间盒子上的内容仍是被压着。
其次:给左右两个盒子加一个定位,加了定位以后左右两个盒子就能够设置left和right值。
代码以下:
.left{ position: relative; left: -200px;}
.right{position: relative;right: -210px;