>  기사  >  웹 프론트엔드  >  圣杯布局与双飞翼布局_html/css_WEB-ITnose

圣杯布局与双飞翼布局_html/css_WEB-ITnose

WBOY
WBOY원래의
2016-06-24 11:19:071307검색

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

圣杯布局

圣杯布局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的左右外边距 来实现;

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.