圣杯布局、双飞翼布局、Flex布局和绝对定位布局的几种经典布局的具体实现示例
题目要求:针对如下DOM结构,编写CSS,实现三栏水平布局,其中left、right分别位于左右两侧,left宽度为200px,right宽度为300px,main处在中间,宽度自适应。
要求:允许增加额外的DOM节点,但不能修改现有节点顺序。
圣杯布局与双飞翼布局针对的都是三列左右栏固定中间栏边框自适应的网页布局(想象一下圣杯是主体是加上两个耳朵;鸟儿是身体加上一对翅膀),圣杯布局是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>
还没有评论,来说两句吧...