码库记事本

码库记事本

浅谈CSS三栏布局的N种实现

小诸哥 0

三栏布局:页面分为左中右三部分。左右固定,中间部分自适应。

1. 绝对定位法

这里的绝对定位是指对左右部分进行绝对定位。

HTML结构。

  1. <div class="left">Left</div>
  2. <div class="main">Main</div>
  3. <div class="right">Right</div&gt;

代码。

  1. //简单的进行CSS reset
  2. body,html{
  3.      height:100%;
  4.      padding: 0px;
  5.      margin:0px;
  6. }
  7. //左右绝对定位
  8. .left,.right{
  9.      position: absolute;
  10.      top:0px;
  11.      background: red;
  12.      height:100%;
  13. }
  14. .left{
  15.      left:0;
  16.      width:100px;
  17. }
  18. .right{
  19.      right:0;
  20.      width:200px;
  21. }
  22. //中间使用margin空出左右元素所占据的空间
  23. .main{
  24.      margin:0px 200px 0px 100px;
  25.      height:100%;
  26.      background: blue;
  27. }
  28. // 上述的高度可以不必进行设置,用内容撑开元素高度即可。
  29.  

height:100%

高度由内容撑开

这种方法有一个弊端,就是如果中间栏含有最小宽度限制,或是含有宽度的内部元素,当浏览器宽度小到一定程度,会发生层重叠的情况。

中间栏内嵌一个宽度为200的span元素,发生重叠

2. 圣杯布局

3. 双飞翼布局

浅谈css双飞翼布局和圣杯布局

4. 自身浮动法

左栏左浮动,右栏右浮动,中间栏放最后

DOM结构

  1. <body>
  2.      <div class="left"></div>
  3.      <div class="right"></div>
  4.      <div class="main"></div>
  5. </body> 

样式

  1.      .left {
  2.          background: red;
  3.          float: left;
  4.          width: 150px;
  5.          }
  6.          .right {
  7.          background: red;
  8.          float: right;
  9.          width: 200px;
  10.          }
  11.          .main {
  12.          background: pink;
  13.          margin: 0 200px 0 150px;
  14.          }

效果

这种方式需要注意三个div的顺序,左右两栏的顺序不分先后,但是中间一栏必须放在最后。

优点是代码足够简洁与高效,缺点是中间主体存在克星,即clear:both属性。如果要使用此方法,需避免明显的clear样式,且主要内容无法最先加载,当页面内容较多时会影响用户体验。

5. flex布局

DOM结构

  1. <div class="container">
  2.          <div class="left">Left</div>
  3.          <div class="main">Main</div>
  4.          <div class="right">Right</div>
  5. </div>

样式

  1. .container {
  2.              display: flex;
  3.          }
  4.          .main {
  5.              flex-grow: 1;
  6.              height: 300px;
  7.              background-color: red;
  8.          }
  9.          .left {
  10.              order: -1;
  11.              flex: 0 1 200px;
  12.              margin-right: 20px;
  13.              height: 300px;
  14.              background-color: blue;
  15.          }
  16.          .right {
  17.              flex: 0 1 100px;
  18.              margin-left: 20px;
  19.              height: 300px;
  20.              background-color: green;
  21.          }

效果

6. table布局

DOM结构

  1. <div class="container">
  2.      <div class="left"></div>
  3.      <div class="main"></div>
  4.      <div class="right"></div>
  5. </div>

样式

  1. .container {
  2.      display: table;
  3.      width: 100%;
  4. }
  5. .left, .main, .right {
  6.      display: table-cell;
  7. }
  8. .left {
  9.      width: 200px;
  10.      height: 300px;
  11.      background-color: red;
  12. }
  13. .main {
  14.      background-color: blue;
  15. }
  16. .right {
  17.      width: 100px;
  18.      height: 300px;
  19.      background-color: green;
  20. }

缺点:无法设置栏间距

End

差不多总结了网上的几种主流方法,有的太小众的方法就没有整理。

CSS3的flex教程还是得好好看一看。

然后还有浮动啊定位啊负边距啊什么的,要深入研究的话估计也是很长的学习笔记。

CSS真是一门玄学。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

标签: 浅谈 CSS 实现