美文网首页
css布局解决方案

css布局解决方案

作者: Bingo是谁 | 来源:发表于2019-01-04 17:26 被阅读0次

    水平居中

    1. 使用inline-block + text-align

    (1) 原理、用法

    • 原理:先将子框由块级元素改变为行内块元素,再通过设置行内块元素居中以达到水平居中。
    • 用法:对子框设置display:inline-block,对父框设置text-align:center。

    (2) 代码示例

    <div class="parent">
        <div class="child>DEMO</div>
    </div>
    
    .child{
        display:inline-block;
    }
    .parent{
        text-align:center;
    }
    

    (3) 优缺点

    • 优点:兼容性好,甚至可以兼容ie6、ie7
    • 缺点:child里的文字也会水平居中,可以在.child添加text-align:left;还原
    使用table+margin

    (1)原理、用法

    • 原理:先将子框设置为块级表格来显示(类似 <table>),再设置子框居中以达到水平居中。
    • 用法:对子框设置display:table,再设置margin:0 auto。

    (2)代码实例

    <div class="parent">
        <div class="child>DEMO</div>
    </div>
    
    .child {
        display:table;
        margin:0 auto;
    }
    

    (3)优缺点:

    • 优点:只设置了child,ie8以上都支持
    • 缺点:不支持ie6、ie7,将div换成table
    使用absolute+transform

    (1)原理、用法

    • 原理:将子框设置为绝对定位,移动子框,使子框左侧距离相对框左侧边框的距离为相对框宽度的一半,再通过向左移动子框的一半宽度以达到水平居中。当然,在此之前,我们需要设置父框为相对定位,使父框成为子框的相对框。
    • 用法:对父框设置position:relative,对子框设置position:absolute,left:50%,transform:translateX(-50%)。

    (2)代码实例

    <div class="parent">
        <div class="child>DEMO</div>
    </div>
    
    .parent {
        position:relative;
    }
    .child {
        position:absolute;
        left:50%;
        transform:translateX(-50%);
    }
    

    (3)优缺点

    • 优点:居中元素不会对其他的产生影响
    • 缺点:transform属于css3内容,兼容性存在一定问题,高版本浏览器需要添加一些前缀,可以把child的margin设置为负值代替,但需要知道child的宽度
    使用flex+justify-content

    (1)原理、用法

    • 原理:通过CSS3中的布局利器flex中的justify-content属性来达到水平居中。
    • 用法:先将父框设置为display:flex,再设置justify-content:center。

    (2)代码实例

    <div class="parent">
        <div class="child>DEMO</div>
    </div>
    
    .parent {
        display:flex;
        justify-content:center;
    }
    

    (3)优缺点

    • 优点:设置parent即可
    • 缺点:低版本浏览器(ie6 ie7 ie8)不支持

    垂直居中

    使用table-cell+vertical-align

    (1)原理、用法

    • 原理:通过将父框转化为一个表格单元格显示(类似 <td> 和 <th>),再通过设置属性,使表格单元格内容垂直居中以达到垂直居中。
    • 用法:先将父框设置为display:table-cell,再设置vertical-align:middle。
      (2)代码实例
    <div class="parent">
        <div class="child>DEMO</div>
    </div>
    
    .parent {
        display:table-cell;
        vertical-align:middle;
    }
    

    (3)优缺点

    • 优点:兼容性较好,ie8以上均支持
    使用absolute+transform

    (1)原理、用法

    • 原理:类似于水平居中时的absolute+transform原理。将子框设置为绝对定位,移动子框,使子框上边距离相对框上边边框的距离为相对框高度的一半,再通过向上移动子框的一半高度以达到垂直居中。当然,在此之前,我们需要设置父框为相对定位,使父框成为子框的相对框。
    • 用法:先将父框设置为position:relative,再设置子框position:absolute,top:50%,transform:translateY(-50%)。
      (2)代码实例
    <div class="parent">
        <div class="child>DEMO</div>
    </div>
    
    .parent {
        position:relative;
    }
    .child {
        position:absolute;
        top:50%;
        transform:translateY(-50%);
    }
    

    (3)优缺点

    • 优点:居中元素不会对其他的产生影响
    • 缺点:transform属于css3内容,兼容性存在一定问题,高版本浏览器需要添加一些前缀

    多列布局

    定宽+自适应

    使用float+overflow

    (1)原理、用法

    • 原理:通过将左边框脱离文本流,设置右边规定当内容溢出元素框时发生的事情以达到多列布局。
    • 用法:先将左框设置为float:left、width、margin-left,再设置实际的右框overflow:hidden。

    (2)代码实例

    <div class="parent">
        <div class="left">
            <p>left</p>
        </div>
        <div class="right">
            <p>right</p>
            <p>right</p>
        </div>
    </div>
    
    .left {
        float:left;
        width:100px;
        margin-right:20px;
    }
    .right {
        overflow:hidden;
    }
    

    (3)优缺点

    • 优点:简单
    • 缺点:不支持ie6
    使用float+margin

    (1)原理、用法

    • 原理:通过将左框脱离文本流,加上右框向右移动一定的距离,以达到视觉上的多列布局。
    • 用法:先将左框设置为float:left、margin-left,再设置右框margin-left。
      (2)代码实例
    <div class="parent">
        <div class="left">
            <p>left</p>
        </div>
        <div class="right">
            <p>right</p>
            <p>right</p>
        </div>
    </div>
    
    .left {
        float:left;
        width:100px;
    }
    .right {
        margin-left:120px;
    }
    

    (3)优缺点

    • 优点:简单,易理解
    • 缺点:兼容性存在一定问题,ie6下有3px的bug。right下的p清除浮动将产生bug
    使用float+margin(改良版)

    (1)原理、用法

    • 原理:在1)的基础之上,通过向右框添加一个父框,再加上设置左、右父框属性使之产生BFC以去除bug。
    • 用法:先将左框设置为float:left、margin-left、position:relative,再设置右父框float:right、width:100%、margin-left,最后设置实际的右框margin-left。

    (2)代码实例

    <div class="parent">
        <div class="left">
            <p>left</p>
        </div>
        <div class="rigth-fix">
            <div class="right">
                <p>right</p>
                <p>right</p>
            </div>
        </div>
    </div>
    
    .left {
        float:left;
        width:100px;
        position:relative;
    }
    .right-fix {
        float:right;
        width:100%;
        margin-left:-100px;
    }
    .right {
        margin-left:120px;
    }
    

    (3)优缺点

    • 优点:简单,易理解
    使用table

    (1)原理、用法

    • 原理:通过将父框设置为表格,将左右边框转化为类似于同一行的td,从而达到多列布局。
    • 用法:先将父框设置为display:table、width:100%、table-layout:fixed,再设置左右框display:table-cell,最后设置左框width、padding-right。

    (2)代码实例

    <div class="parent">
        <div class="left">
            <p>left</p>
        </div>
        <div class="right">
            <p>right</p>
            <p>right</p>
        </div>
    </div>
    
    .parent {
        display:table;
        width:100%;
        table-layout:fixed;
    }
    .left {
        width:100px;
        padding-right:20px;
    }
    .right,.left {
        display:table-cell;    
    }
    
    使用flex

    (1)原理、用法

    • 原理:通过设置CSS3布局利器flex中的flex属性以达到多列布局。
    • 用法:先将父框设置为display:flex,再设置右框flex:1,最后设置左框width、margin-right。

    (2)代码实例

    <div class="parent">
        <div class="left">
            <p>left</p>
        </div>
        <div class="right">
            <p>right</p>
            <p>right</p>
        </div>
    </div>
    
    .parent {
        display:flex;
    }
    .left {
        width:100px;
        margin-right:20px;
    }
    .right {
        flex:1;
    }
    

    (3)优缺点

    • 优点:flex很强大
    • 缺点:兼容性存在一定问题,性能存在一定问题

    全屏布局

    全屏布局的特点

    • 滚动条不是全局滚动条,而是出现在内容区域里,往往是主内容区域
    • 浏览器变大时,撑满窗口

    全屏布局的方法

    使用position

    (1)原理、用法

    • 原理:将上下部分固定,中间部分使用定宽+自适应+两块高度一样高。
    • 用法:见实例。
      (2)代码实例
    <div class="parent">
        <div class="top">top</div>
        <div class="left">left</div>
        <div class="right">
            <div class="inner">right</div>
        </div>
        <div class="bottom">bottom</div>
    </div>
    
    html,body,.parent{
        margin:0;
        height:100%;
        overflow:hidden;
    }
    body{
        color:white;
    }
    .top{
        position:absolute;
        top:0;
        left:0;
        right:0;
        height:100px;
        background:blue;
    }
    .left{
        position:absolute;
        left:0;
        top:100px;
        bottom:50px;
        width:200px;
        background:red;
    }
    .right{
        position:absolute;
        left:200px;
        top:100px;
        bottom:50px;
        right:0;
        background:pink;
        overflow: auto;
    }
    .right .inner{
        min-height: 1000px;
    }
    .bottom{
        position:absolute;
        left:0;
        right:0;
        bottom:0;
        height:50px;
        background: black;
    }
    

    (3)优缺点

    • 优点:兼容性好,ie6下不支持
    使用flex

    (1)原理、用法

    • 原理:通过灵活使用CSS3布局利器flex中的flex属性和flex-direction属性以达到全屏布局。
    • 用法:见实例。
      (2)代码实例
    <div class="parent">
        <div class="top">top</div>
        <div class="middle">
            <div class="left">left</div>
            <div class="right">
                <div class="inner">right</div>
            </div>
        </div>
        <div class="bottom">bottom</div>
    </div>
    
    html,body,.parent{
        margin:0;
        height:100%;
        overflow:hidden;
    }
    body{
        color: white;
    } 
    .parent{
        display: flex;
        flex-direction: column;
    }
    .top{
        height:100px;
        background: blue;
    }
    .bottom{
        height:50px;
        background: black;
    }
    .middle{
        flex:1;
        display:flex;
    }
    .left{
        width:200px;
        background: red;
    }
    .right{
        flex: 1;
        overflow: auto;
        background:pink;
    }
    .right .inner{
        min-height: 1000px;
    }
    

    (3)优缺点

    • 缺点:兼容性差,ie9及ie9以下不兼容

    参考文章:
    CSS布局解决方案(终结版)

    相关文章

      网友评论

          本文标题:css布局解决方案

          本文链接:https://www.haomeiwen.com/subject/lyckrqtx.html