CSS布局

2019-05-05  本文已影响0人  明明你也一样

CSS 布局基础

1. 水平居中

子元素为行内元素还是块状元素,由于给行内元素设置宽高是无效的,这里只考虑块级元素宽度一定还是宽度未定,针对不同的情况采取的布局方案也不同。下面进行分析:

2. 垂直居中

垂直居中对于子元素是单行内联文本、多行内联文本以及块状元素采用的方案是不同的。

3. 左右布局

使用浮动进行布局

    .clearfix::after{
        content:"";
        display:block;
        clear:both;
    }
    .right,.left{
        float:left;
    }
    <div class="clearfix">
            <div class="left"><div>
            <div class="right"><div>
    </div>

4. 左中右布局

双飞翼布局(float + 负margin + margin)是圣杯布局的升级版,所以这里不推荐圣杯布局。

原理说明:

双飞翼布局和圣杯布局的思想有些相似,都利用了浮动和负边距,但双飞翼布局在圣杯布局上做了改进,在main元素上加了一层div, 并设置margin,由于两侧栏的负边距都是相对于main-wrap而言,main的margin值变化便不会影响两个侧栏,因此省掉了对两侧栏设置相对布局的步骤。

代码块:

    .main-wrap {        
        float: left;       
        width: 100%;   
    }  
    .sub {       
        float: left;        
        width: 190px;        
        margin-left: -100%;   
    }   
    .extra {        
        float: left;        
        width: 230px;        
        margin-left: -230px; 
    }
    .main {    
        margin: 0 230px 0 190px;
    }

    <div id="main-wrap" class="column">
        <div id="main">#main</div>
    </div>
    <div class="sub"></div>        
    <div class="extra"></div>

布局步骤:

  1. 三者都设置向左浮动。
  2. 设置main-wrap宽度为100%,设置两个侧栏的宽度。
  3. 设置 负边距,sub设置负左边距为100%,extra设置负左边距为负的自身宽度。
  4. 设置main的margin值给左右两个子面板留出空间。

一些说明

5. 其他布局技巧

flex布局

参考资源

阮一峰的博客----flex布局语法
阮一峰的博客----flex布局案例

以下是五种布局的flex布局代码:

    .layout {
        display: flex;
    }
    .layout__main {
        flex: 1;
    }
    .layout__aside {
        width: 200px;
    }
    <div class="layout">
        <aside class="layout__aside">侧边栏宽度固定</aside>
        <div class="layout__main">主内容栏宽度自适应</div>
    </div>
    <div class="layout">
        <div class="layout__main">主内容栏宽度自适应</div>
        <aside class="layout__aside">侧边栏宽度固定</aside>
    </div>
    <div class="layout">
        <aside class="layout__aside">左侧边栏宽度固定</aside>
        <div class="layout__main">主内容栏宽度自适应</div>
        <aside class="layout__aside">右侧边栏宽度固定</aside>
    </div>
    <div class="layout">
        <aside class="layout__aside">第1个侧边栏宽度固定</aside>
        <aside class="layout__aside">第2个侧边栏宽度固定</aside>
        <div class="layout__main">主内容栏宽度自适应</div>
    </div>
    <div class="layout">
        <div class="layout__main">主内容栏宽度自适应</div>
        <aside class="layout__aside">第1个侧边栏宽度固定</aside>
        <aside class="layout__aside">第2个侧边栏宽度固定</aside>
    </div>

与之前所讲的几种传统布局方案相比,flex布局的代码可谓异常简洁,而且非常通用,利用简单的三行CSS即实现了常见的五种布局。

上一篇下一篇

猜你喜欢

热点阅读