美文网首页前端前端面试题详解阿拉蕾
圣杯布局和双飞翼布局(前端面试必看)

圣杯布局和双飞翼布局(前端面试必看)

作者: 森西悠然 | 来源:发表于2016-07-17 18:58 被阅读28504次
爱生活,不爱黑眼圈

稍微了解前端的人都知道,圣杯布局和双飞翼布局是前端面试时必问的问题,因为它既能体现你懂HTML结构又能体现出你对DIV+CSS布局的掌握,毕竟我们学习CSS主要就是为了更好地布局带来最好的用户体验嘛~

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

圣杯布局的出现是来自于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%。

第二步:给出每个盒子的样式
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)该上阵了。

第四步:利用负边距布局

1.让左边的盒子上去

需要设置其左边距为负的中间盒子的宽度,也就是.left {margin-left:-100%;}。这样左盒子才可以往最左边移动。

2.让右边的盒子上去

需要设置其左边距为负的自己的宽度,也就是.right {margin-left:-200px;}。这样右盒子才可以在一行的最右边显示出自己。

第五步:看此时的效果图

实现固比固布局
到这里,是不是感觉很有成就感?但是很遗憾的告诉你,还没结束哦!
我们现在的确是硬性的实现了固比固布局。但是要记住,中间盒子是自适应的宽度,所以中间盒子里的内容会被左右盒子给压住一部分。
比如现在我给中间盒子加很多的内容,大家看看效果图:
中间盒子的内容被盖住
所以,我们的工作还没停止。

第六步:让中间自适应的盒子安全显示

首先:利用父级元素设置左右内边距的值,把父级的三个子盒子往中间挤。

代码如下:.container{ padding: 0 200px;} 这里的200px是左右盒子的宽度。
效果如下:

利用父级的内边距将盒子往中间挤
我们可以看到,左右两边的内边距是有了,但是中间盒子上的内容还是被压着。

其次:给左右两个盒子加一个定位,加了定位之后左右两个盒子就可以设置left和right值。

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

第七步:看最终效果图

圣杯布局大功告成啦!

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


真心希望对你有帮助。

相关文章

网友评论

  • 4832f0f9781f:middle设置box-sizing:border-box; padding:0 210px 0 210px;
    可以实现相同的效果;
    zjlyyq:@Z强_eea6 是的,博主的方法有点绕
  • 徐丶清风:第二步container不需设置高度;
    最后一步是.right{position: relative;right: -200px;}(你写成了210px)
  • 易_刺猬:如果你看完了全篇文章,并且看到了评论,那我建议你,再去百度搜索看圣杯布局和双飞翼布局,这篇文章代码演示部分,全是错乱的,他的错误我不一一列举。
    如果不是真心想学知识,那就忽略我的评论
    leoying:我看了网上的例子基本上都是这么做的
  • 98faa6e52002:写得非常详细,受教了
  • 8e784c4f1e17:为什么我左右俩边的div显示不出来
  • 63eef4ef2bc5:这布局在页面的宽缩至608px时布局就会崩掉,所以还在做屏幕自适应处理
  • 月痕影:第三步的效果图好像有点问题,如作者所示css代码布局之后左右两边的div会消失
  • 95e90ece1c61:你的container 设置了overflow:hidden 以后你确定左右两个 还显示吗
  • WX一副良药:跟下来了,效果也实现了,感谢!
  • 0_0_0_0_0_0_0:楼主文章写的不错,清晰明白,我有一个问题,假如你的左右两边的那两个方框的宽度值变化了后,是不是还得一个一个的去重新设置宽度 200px? 这样写代码是不是太费劲了呢?
  • 8b4babc2e465:.container{ height:200px;overflow:hidden;}
    这里不应该设height:200px; 吧。
  • 爱影斯坦:写的很棒
  • 占飞_f9b3:可以用弹性盒模型解决,更简洁。
    leoying:pc端为了解决兼容性问题, 所以flex不是万能的。
  • 坤少卡卡:通俗易懂,赞
  • 28b4bd7541a3:第二步里的container中的样式中的height得设置成400px,200px会隐藏left与right这两个块
    LeahTian:如果我理解得没错的话,他设置的目的应该是清除浮动,但是应该是设置width,而不是设置height吧,而且这种的话,是不能与position一起用的
    Hathaway_桉:我怎么觉得container不应该设置高度那?
  • 一言不合拔萝卜:谢谢作者提到了,圣杯布局的由来,我说怎么看都不觉得长得像圣杯啊....
  • 67f0d5bfa5d0:其实这个是圣杯布局
    Randoom:”现在,圣杯布局终于搞定了,也实现了我们要的效果”,哈哈,写的就是圣杯布局
  • b10a37ade8c5:你这样太麻烦了 给中间.middle {width: calc(100% - 400px);margin: 0 auto;}宽度这样设置就好了
    郑州程序员王一:@mayufo 性能哪里不好了?能说下嘛
    mayufo:这种写法性能不好
    江湖中人1220:这个写法我用过,不过只能兼容IE9及以上版本;IE8不行!
  • 32abca0a0eaa:感觉写的有点啰嗦了,定位其实可以不用了,中间的盒子设置{padding-right: 200px;padding-left: 200px;box-sizing: border-box;},至于啰嗦是觉得如果用了定位的话,-margin都不要用了,浮动也可以不要了直接定位就好了,这样不是更好理解吗。个人简介
    Meahu:box-sizing 有兼容性问题
    ccee2035c0cb:不行呀,我的字还是寄出去了
    e294eafb7674:如果给中间的盒子设置padding的话不太好,设置盒子间的间距会比较麻烦...其实是占用了以后可能的使用场景...
  • 逆流成河wsy:写的真好😃
  • 41b9b0c733c4:赞
    写给我的公主的简书:@一袭白衣衫 http://www.cnblogs.com/2050/archive/2012/08/13/2636467.html
    这里有解释
    b14a5554c056:.left设置margin-left:-100%; 为什么会上去吗?

本文标题:圣杯布局和双飞翼布局(前端面试必看)

本文链接:https://www.haomeiwen.com/subject/ultpjttx.html