• 圣杯布局与双翼布局(前端面试必看)


     

     
    爱生活,不爱黑眼圈

    稍微了解前端的人都知道,圣杯布局和双飞翼布局是前端面试时必问的问题,因为它既能体现你懂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>

    写结构的时候要注意,父元素的的三栏务必先写中间盒子。因为中间盒子是要被优先渲染嘛~并且设置其自适应,也就是100%。

    第二步:给出每个盒子的样式
    header{ 100%;height: 40px;background-color: darkseagreen;}
    .container{ height:200px;overflow:hidden;}
    .middle{ 100%;height: 200px; background-color: deeppink;float:left;}
    .left{ 200px;height: 200px;background-color: blue;float:left;}
    .right{ 200px;height: 200px;background-color: darkorchid;float:left;}
    footer{ 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;

    第七步:看最终效果图

     
    圣杯布局大功告成啦!

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

    双翼布局:

    与圣杯布局差不多,就是在main里面放一层maininner,padding:0 200px 即可,不要在container中使用padding,同时left和right也不要position定位了

  • 相关阅读:
    shell脚本,通过传入的参数来计算最大值和最小值以及平均值。
    mac date命令
    jstorm系列-2:入门
    jstorm系列-1:入门
    git 如何恢复只是提交到本地的文件(或者commit)
    shell 参数
    shell 运算符
    shell 中的<,<<,>,>>
    shell 学习笔记
    java 多线程剖析
  • 原文地址:https://www.cnblogs.com/liangshuang/p/8472284.html
Copyright © 2020-2023  润新知