圣杯布局和双飞翼布局的实现过程

相信很多人都搜过圣杯布局和双飞翼布局,也知道他们的由来,在这里我就不一一赘述了,今天主要讲的是当我遇到两个布局时,我是怎样一步一步从开始到实现的过程,例如:刚开始我也不懂为什么圣杯布局和双飞翼布局的区别,不懂圣杯布局为什么会有相对定位等一些问题,在这里给大家讲下我的理解,如有错误,欢迎批评指正。

好了,接下来开始今天的写文章之旅!

圣杯布局和双飞翼布局实现的问题都是三列布局,两边定宽,中间自适应布局,要注意的是中间栏(重要的东西)要在放在文档流前面以优先渲染。

圣杯布局

1、首先定义三列,为它们设置简单的css样式,代码如下:

[html] view plain copy

  1. <!-- 圣杯布局 -->
  2. <!DOCTYPE html>
  3. <html>
  4. <head>
  5. <style>
  6. .left{
  7. background: #E79F6D;
  8. width:150px;
  9. float:left;
  10. }
  11. .main{
  12. background: #D6D6D6;
  13. width:100%;
  14. float:left;
  15. }
  16. .right{
  17. background: #77BBDD;
  18. width:190px;
  19. float:left;
  20. }
  21. </style>
  22. </head>
  23. <body>
  24. <div class="con">
  25. <div class="main">Main</div>
  26. <div class="left">Left</div>
  27. <div class="right">Right</div>
  28. </div>
  29. </body>
  30. </html>

实现效果图:

这就是普通的让三个div左浮动显示出来的效果;

2、我们让Left和Right与main在同一排,这里需要用到margin-left的负值,这里如果margin-left是负值,我理解的是在此基础上往左边移,设置Left的margin-left:-100%,也就是往左移main的整个宽度,这时Left的左边缘跟main的左边缘重叠,即Left的150px宽覆盖住了main的150px宽;

这时Right跑到左边了,再对Right设置margin-left:-190px;即right也跑到上面去了,Right的右边缘和main的右边缘对齐,Right的宽度覆盖了main的右边的宽度;现在Left和Right都跑上面去了,但是需要注意的是main的值不见了,因为它被覆盖了,设置left和right的margin值只是改变Left和Right的位置,对于main来说还是在以前的位置上,接下来要考虑的问题就是如何定位main的位置?

3、需要给con容器加padding值,padding值的作用是给这整个容器均移动padding值,如在刚开始Left和Right没上移的时候,给con加padding值的效果如下:

现在在Left和Right以及main都在同一排的情况下,加padding的值,就把main的定位到合适的位置了,但是这时的问题是:Left和Right也跟着一起缩了,所以要把Left和Right定位带之前的位置,该怎么定位呢?

4、这时Left和Right需要用到css 的left属性了,left 属性规定元素的左边缘,该属性定义了定位元素左外边距边界与其包含块左边界之间的偏移。注意使用属性left的时候要给这个元素定位,绝对定位和相对定位都可以,如果不使用定位的话没有效果,具体为什么我也不知道,大家可以自行百度。

Left的css样式加上:position:relative;left:-150px;  同理css的right属性也是如此,position:relative;right:-190px;  Left和Right回到它们各自的位置上,OK,完成圣杯的布局,效果图贴上:

完整代码:

[html] view plain copy

  1. <!-- 圣杯布局 -->
  2. <!DOCTYPE html>
  3. <html>
  4. <head>
  5. <style>
  6. .con {
  7. padding-left: 150px;
  8. padding-right: 190px;
  9. }
  10. .left{
  11. background: #E79F6D;
  12. width:150px;
  13. float:left;
  14. margin-left: -100%;
  15. position: relative;
  16. left:-150px;
  17. }
  18. .main{
  19. background: #D6D6D6;
  20. width:100%;
  21. float:left;
  22. }
  23. .right{
  24. background: #77BBDD;
  25. width:190px;
  26. float:left;
  27. margin-right: -190px;
  28. position: relative;
  29. right: -190px;
  30. }
  31. </style>
  32. </head>
  33. <body>
  34. <div class="con">
  35. <div class="main">Main</div>
  36. <div class="left">Left</div>
  37. <div class="right">Right</div>
  38. </div>
  39. </body>
  40. </html>

双飞翼布局

双飞翼布局可以看成是对圣杯布局的改进,因为圣杯布局用到的标签属性较多,用着也较麻烦,所以淘宝玉伯大大就提出来双飞翼的布局,双飞翼是把三列布局比作鸟,中间栏是鸟身,两边宽是鸟的两翼,重要的是鸟的身体摆好,再安两翼。思路和圣杯布局一样,这里我还是以上一个作例子,用到main,left,right(其实用main  sub  extra更形象)。前两步都是一样的,重要的是第三步,在前两步的完成后已经形成同行排列,只不过main值被覆盖了,圣杯布局的第三步是给con容器添加padding属性,而双飞翼布局是为main里面的内容再加一个div,让main的内容包含在内层div里,

[html] view plain copy

  1. <body>
  2. <div class="con">
  3. <div class="main">
  4. <div class="mc">Main</div>
  5. </div>
  6. <div class="left">Left</div>
  7. <div class="right">Right</div>
  8. </div>
  9. </body>

这时,只要设置mc的margin属性就可以实现三列布局了,而且main也正常显示;这里,不用设置con容器的padding属性,也不用给Left和Right运用left,right属性,因为设置padding属性就是为了不覆盖main的值,现在将main里的内容放在一个div里,再为它设置margin属性,也就实现了不遮挡main里面的内容值,因此双飞翼布局使用属性个数减少,看着更简便。代码如下:

[html] view plain copy

  1. <!-- 双飞翼布局 -->
  2. <!DOCTYPE html>
  3. <html>
  4. <head>
  5. <style>
  6. .left{
  7. background: #E79F6D;
  8. width:150px;
  9. float:left;
  10. margin-left: -100%;
  11. }
  12. .main{
  13. background: #D6D6D6;
  14. width:100%;
  15. float:left;
  16. }
  17. .mc {
  18. margin-left: 150px;
  19. }
  20. .right{
  21. background: #77BBDD;
  22. width:190px;
  23. float:left;
  24. margin-right: -190px;
  25. }
  26. </style>
  27. </head>
  28. <body>
  29. <div class="con">
  30. <div class="main">
  31. <div class="mc">Main</div>
  32. </div>
  33. <div class="left">Left</div>
  34. <div class="right">Right</div>
  35. </div>
  36. </body>
  37. </html>

OK,两个布局的过程讲解结束,谢谢大家,欢迎大家批评指正!

原文地址:https://www.cnblogs.com/honghebin/p/8270855.html

时间: 2024-08-08 23:19:09

圣杯布局和双飞翼布局的实现过程的相关文章

css布局之圣杯布局和双飞翼布局

圣杯布局和双飞翼布局 今天看了很多圣杯布局和双飞翼布局的技术博客,通过自己的理解总结一下吧. 1.二者相同点: 实现的都是三栏布局,两边的盒子宽度固定,中间盒子自适应,也就是我们常说的固比固布局.它们实现的效果是一样的. 2.不同点: 圣杯布局知识点:浮动,负边距,相对定位,不需要添加额外标签. 双飞翼:只用到浮动,负边距,不需要使用相对定位,需要添加一个额外的标签. 注意:html结构中中间部分要写在左右布局之前,为了优先渲染. 下面就先来看一下圣杯布局的实现过程吧: 先写出基本DOM结构:

圣杯布局和双飞翼布局的理解和区别

圣杯布局和双飞翼布局基本上是一致的,都是两边固定宽度,中间自适应的三栏布局,其中,中间栏放到文档流前面,保证先行渲染.解决方案大体相同,都是三栏全部float:left浮动,区别在于解决中间栏div的内容不被遮挡上,圣杯布局是中间栏在添加相对定位,并配合left和right属性,效果上表现为三栏是单独分开的(如果可以看到空隙的话),而双飞翼布局是在中间栏的div中嵌套一个div,内容写在嵌套的div里,然后对嵌套的div设置margin-left和margin-right,效果上表现为左右两栏在

圣杯布局和双飞翼布局

圣杯布局和双飞翼布局基本上是一致的,都是两边固定宽度,中间自适应的三栏布局,其中,中间栏放到文档流前面,保证先行渲染.解决方案大体相同,都是三栏全部float:left浮动,区别在于解决中间栏div的内容不被遮挡上,圣杯布局是中间栏在添加相对定位,并配合left和right属性,效果上表现为三栏是单独分开的(如果可以看到空隙的话),而双飞翼布局是在中间栏的div中嵌套一个div,内容写在嵌套的div里,然后对嵌套的div设置margin-left和margin-right,效果上表现为左右两栏在

对于圣杯布局和双飞翼布局的新认识

今天刷题的时候碰见了一道要求使用双飞翼布局的题.于是便对比了一下圣杯布局得到了点新认识. 我们都知道圣杯布局和双飞翼布局都实现了中间宽度自适应,两边定宽的效果.这样做的优势是重要的东西放在文档流前面可以优先渲染.两者又有什么差别呢? 对比圣杯布局和双飞翼布局 1.二者都主要使用了浮动和负边距来达到中间宽度自适应,两边定宽的目的. 具体来说就是设置左右两边div的margin-left为一负值并设置浮动.于是便会移动到上方的div内(也就是中间的div)与之重叠. 2.相比于圣杯布局双飞翼布局没有

圣杯布局,双飞翼布局详解

圣杯布局和双飞翼布局解决的问题是一样的,都是用来解决左右定宽,中间自适应的三栏布局,中间栏要放在文档流前面以优先渲染. 圣杯布局和双飞翼布局:三栏全部加上float:left,左右两栏加上负margin,以形成三栏布局. 圣杯布局:大的div设置padding-left和padding-right,左右两个div用相对布局position: relative,加上right和left属性.双飞翼布局:中间div内加一层标签,在设置内层标签的margin html圣杯布局: <div class=

圣杯布局和双飞翼布局的作用和区别

圣杯布局和双飞翼布局解决的问题是一样的,就是两边顶宽,中间自适应的三栏布局,中间栏要在放在文档流前面以优先渲染. 圣杯布局和双飞翼布局解决问题的方案在前一半是相同的,也就是三栏全部float浮动,但左右两栏加上负margin让其跟中间栏div并排,以形成三栏布局. 不同在于解决”中间栏div内容不被遮挡“问题的思路不一样:圣杯布局,为了中间div内容不被遮挡,将中间div设置了左右padding-left和padding-right后,将左右两个div用相对布局position: relativ

圣杯布局与双飞翼布局

圣杯布局和双飞翼布局的目的都是:左右两栏固定宽度,中间部分自适应: 圣杯布局 圣杯布局HTML: <div class="wrap"> <div class="main"> 我是主要 </div> <div class="left"> 我是左边 </div> <div class="right"> 我是右边 </div> </div>

圣杯布局and双飞翼布局

*圣杯布局 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>ajax</title> <style> *{ padding:0; margin:0 } .header{ width:100%; background:#e1ef05; height:50px; } /*main写前目的是让它先加载*/ .main{ padding:0

认识圣杯布局和双飞翼布局

各种各样的布局,无非就是用了浮动 float,负边距,相对定位,通过这三者的巧妙组合跟拼凑来实现的.用好这些,布局就会很简单. 还没学会布局时,就听到有圣杯布局和双飞翼布局,这布局都有这么风骚的名字,就觉得很酷,事实也如此,了解了圣杯布局和双飞翼布局,才发现挺深奥的. 传统的布局中,当我们需要改变两栏的互换,就会很麻烦.因为还要涉及到 HTML 代码的修改,不能完全从 CSS 上更改,这叫 HTML 和 CSS 的耦合.而圣杯布局跟双飞翼布局就是能够不考虑主体的位置,能够只通过 CSS 代码就改