圣杯布局、双飞翼布局、Flex布局和绝对定位布局实例

转自CSDN博客

前提:

针对如下DOM结构,编写CSS,实现三栏水平布局,其中left、right分别位于左右两侧,left宽度为200px,right宽度为300px,main处在中间,宽度自适应。 

<div class="container">
<div class="main"></div>
<div class="left"></div>
<div class="right"></div>
</div>

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

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

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

  • 允许任意列的高度最高

方法一:圣杯布局

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>transform</title>

<style>

.container {
padding: 0 200px 0 200px;
}
.left, .main, .right{
position: relative;
min-height: 200px;
float: left;
color: white;
}
.left{
background: green;
left: -200px;/*把left移动到留白处*/
width: 200px;
margin-left: -100%;
/* 设置left部分的margin-left为-100%,就会使left向左移动一整个行的宽度,由于left左边是父元素的边框,所以left继续跳到上一行左移,一直移动到上一行的开头,并覆盖了main部分*/
}
.main{
background: blue;
width: 100%;
}
.right{
background: red;
width: 200px;
margin-left: -200px;
right: -200px; /*把right移动到留白处*/
}

</style>
</head>
<body>

<div class="container">
<div class="main">main</div>
<div class="left">left</div>
<div class="right">right</div>
</div>

</body>
</html>

方法二:双飞翼布局

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>transform</title>

<style>

.left, .main, .right {
float: left;
min-height: 200px;
text-align: center;
}
.left {
margin-left: -100%;
background: green;
width: 200px;
}

.right {
margin-left: -300px;
background-color: red;
width: 300px;
}
.main {
background-color: blue;
width: 100%;
}
.content{
margin: 0 300px 0 200px;
}

</style>
</head>
<body>

<div class="container">
<div class="main">
<div class="content">main</div>
</div>
<div class="left">left</div>
<div class="right">right</div>
</div>

</body>
</html>

方法三:Flex布局

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>transform</title>

<style>

.left, .main, .right {
float: left;
min-height: 200px;
text-align: center;
}
.left {
margin-left: -100%;
background: green;
width: 200px;
}

.right {
margin-left: -300px;
background-color: red;
width: 300px;
}
.main {
background-color: blue;
width: 100%;
}
.content{
margin: 0 300px 0 200px;
}

</style>
</head>
<body>

<div class="container">
<div class="main">
<div class="content">main</div>
</div>
<div class="left">left</div>
<div class="right">right</div>
</div>

</body>
</html>

方法四:绝对定位布局

绝对定位,就相当于万金油一样的存在,不论什么样的布局,使用绝对定位都能实现

 

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>transform</title>

<style>

.container{
position: relative;
}
.main,.right,.left{
top: 0;
height: 130px;
}
.main{
margin: 0 300px 0 200px;
background-color: blue;
}
.right{
position: absolute;
width: 300px;
right: 0;
background-color: red;
}
.left{
position: absolute;
width: 200px;
background-color: green;
left: 0;
}
</style>
</head>
<body>

<div class="container">
  <div class="main">main</div>
  <div class="left">left</div>
  <div class="right">right</div>
</div>
</div>

</body>
</html>

posted @ 2018-08-23 16:41  Sueing  阅读(270)  评论(1编辑  收藏  举报
[URL=https://info.flagcounter.com/X5yY][IMG]https://s05.flagcounter.com/map/X5yY/size_s/txt_000000/border_CCCCCC/pageviews_0/viewers_0/flags_0/[/IMG][/URL]