码迷,mamicode.com
首页 > 其他好文 > 详细

圣杯布局与双飞翼布局

时间:2016-05-01 19:01:04      阅读:144      评论:0      收藏:0      [点我收藏+]

标签:

圣杯布局和双飞翼布局的目的都是:左右两栏固定宽度,中间部分自适应;

圣杯布局

圣杯布局HTML

<div class="wrap">
  <div class="main">
    我是主要
  </div>
  <div class="left">
    我是左边
  </div>
  <div class="right">
    我是右边
  </div>
</div>

圣杯布局CSS:

* {
    margin: 0;
    padding: 0
}

.main {
    background-color: yellow;
    height: 100px;
    float: left;
    width: 100%;
}

.left {
    background-color: red;
    width: 200px;
    height: 100px;
    float: left; 
    margin-left: -100%; /*margin负边距*/
    position: relative; /*相对自身偏移*/
    left: -200px; 
}

.right {
    background-color: blue;
    width: 200px;
    height: 100px;
    float: left;
    margin-left: -200px; /*margin负边距*/
    position: relative;  /*相对自身偏移*/
    right: -200px;   
}

.wrap {
    padding: 0 200px;  /*父级设置padding*/
}

圣杯布局的优点

  使主要内容列先加载。
  允许任何列是最高的。
  没有额外的div。
  需要的hack很少。

双飞翼布局

 双飞翼HTML

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8"/>
        <title>
            双飞翼布局
        </title>
        <link rel="stylesheet" href="main.css"/>
    </head>
    <body>
        <div class="main-wrap">  <!-- 把main嵌套在一个div里面 -->
            <div class="main">   
                我是主要
            </div>
        </div>
        <div class="left">
            我是左边
        </div>
        <div class="right">
            我是右边
        </div>
    </body>
</html>

双飞翼CSS

.main-wrap {
    float: left;
    width: 100%;
}

.main {
    height: 100px;
    margin-left: 200px;  /*利用左、右外边距定位*/
    margin-right: 200px;
    background-color: yellow;
}

.left {
    background-color: red;
    width: 200px;
    height: 100px;
    float: left;
    margin-left: -100%;
}

.right {
    background-color: blue;
    width: 200px;
    height: 100px;
    float: left;
    margin-left: -200px;
}

圣杯布局和双飞翼的比较

1.两种布局都是把主要内容放在前面加载;

2.布局有相似之处,都使用了负外边距来布局;

3.不同:

圣杯布局是设置 父容器的padding值、相对定位来实现;

双飞翼布局是给main添加了一个div容器、设置main的左右外边距 来实现;

圣杯布局与双飞翼布局

标签:

原文地址:http://www.cnblogs.com/webcome/p/5450784.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!