圣杯布局、双飞翼布局、Flex布局和绝对定位布局的几种经典布局的具体实现示例

分手后的思念是犯贱 2022-03-16 07:30 256阅读 0赞

题目要求:针对如下DOM结构,编写CSS,实现三栏水平布局,其中left、right分别位于左右两侧,left宽度为200px,right宽度为300px,main处在中间,宽度自适应。
要求:允许增加额外的DOM节点,但不能修改现有节点顺序。


  
main

  
left

  
right

   圣杯布局与双飞翼布局针对的都是三列左右栏固定中间栏边框自适应的网页布局(想象一下圣杯是主体是加上两个耳朵;鸟儿是身体加上一对翅膀),圣杯布局是Kevin Cornell在2006年提出的一个布局模型概念,在国内最早是由淘宝UED的工程师(传说是玉伯)改进并传播开来,在中国也有叫法是双飞翼布局,它的布局要求有几点:

三列布局,中间宽度自适应,两边定宽;

中间栏要在浏览器中优先展示渲染;

允许任意列的高度最高;

可以看出我们题目的要求跟圣杯布局和双飞翼布局要求一样。

下面我们看看具体的实现方法。

方法一:圣杯布局
1.设置基本样式

/*3.圣杯布局法*/
.left, .main, .right {
min-height: 130px;
}
.left {
background: green;
width: 200px;
}
.main {
background-color: blue;
}
.right {
background-color: red;
width: 300px;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
为了高度保持一致给left main right都加上min-height:130px。

2.圣杯布局是一种相对布局,首先设置父元素container的位置:  

.container {
padding: 0 300px 0 200px;
}
1
2
3
实现效果是左右分别空出200px和300px区域,效果如图:

3.将主体部分的三个子元素都设置左浮动

.left, .main, .right {
min-height: 130px;
float: left;
}
1
2
3
4
出现了如下情况,怎么办,别着急慢慢来:

4.设置main宽度为width:100%,让其单独占满一行

.main {
background-color: blue;
width: 100%;
}
1
2
3
4

5.设置left和right 负的外边距

  我们的目标是让left、main、right依次并排,但是上图中left和right都是位于下一行,这里的技巧就是使用负的margin-left:

.left {
margin-left: -100%;
background-color: green;
width: 200px;
}
.right {
margin-left: -300px;
background-color: red;
width: 300px;
}
1
2
3
4
5
6
7
8
9
10
  负的margin-left会让元素沿文档流向左移动,如果负的数值比较大就会一直移动到上一行。关于负的margin的应用也是博大精深,这里肯定是不能详细介绍了。
  设置left部分的margin-left为-100%,就会使left向左移动一整个行的宽度,由于left左边是父元素的边框,所以left继续跳到上一行左移,一直移动到上一行的开头,并覆盖了main部分(仔细观察下图,你会发现main里面的字“main”不见了,因为被left遮住了),left上移过后,right就会处于上一行的开头位置,这时再设置right部分margin-left为负的宽度,right就会左移到上一行的末尾。

6.接下来只要把left和right分别移动到这两个留白就可以了。可以使用相对定位移动 left和right部分。

.left, .main, .right {
position: relative;
min-height: 130px;
float: left;
}
.left {
left: -200px;
margin-left: -100%;
background: green;
width: 200px;
}
.right {
right: -300px;
margin-left: -300px;
background-color: red;
width: 300px;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

至此,我们完成了三列中间自适应的布局,也就是传说中的圣杯布局。完整的代码如下:

<!DOCTYPE html>




实现三栏水平布局之圣杯布局




  
main

  
left

  
right



发表评论

表情:
评论列表 (有 0 条评论,256人围观)

还没有评论,来说两句吧...

相关阅读

    相关 布局布局

    圣杯布局和双飞翼布局解决的问题是一样的,就是两边定宽,中间自适应的三栏布局,中间栏要在放在文档流前面以优先渲染。 两者相同之处是实现三栏布局,都是利用float浮动加上左右两

    相关 布局布局

    圣杯布局和双飞翼布局,虽然两者的实现方法略有差异,不过都遵循了以下要点: 两侧宽度固定,中间宽度自适应 中间部分在 DOM 结构上优先,以便先行渲染 允许三

    相关 布局布局

    圣杯布局 圣杯布局就是三栏布局,其中左右两栏固定宽度,中间部分自适应 主要步骤: 1. 在html中,中间的块在最前面,后面紧跟左边的块和右边的块 2. 三者均