CSS多列布局方案

本文详细介绍了使用CSS进行多列布局的各种方案,包括定宽与自适应、多列定宽与自适应、不定宽与自适应、多列不定宽与自适应、等分布局和等高布局。涉及的技术包括float、margin、overflow、table和flex布局。同时,文章针对不同布局方法在IE浏览器的兼容性问题进行了说明和解决方案的提供。
摘要由CSDN通过智能技术生成

一、定宽与自适应

1、float+margin

float元素的宽度默认为内容宽度,半脱离文档流,对元素,脱离文档流,对内容,在文档流。向指定的方向一直移动。float元素在同一文档流。
兼容性问题: IE6下当浮动元素与非浮动元素相邻时,3px的Bug就会出现,它会偏移3像素。
解决方案:.left设置margin-right为-3px

HTML

<div class="parent">
        <div class="left">
                <p>left</p>     
        </div>
        <div class="right">
                <p>right</p>
                <p>right</p>        
        </div>
</div>

CSS

.left{
        float:left;
        width:100%;
}
.right{
        margin-left:120px;
}

2、float+margin+(fix)

该方法是对第1个方法的改进,修复了第1个方法中“3像素”的问题。

HTML

<div class="parent">
        <div class="left">
                <p>left</p>     
        </div>
        <div class="right-fix">
                <div class="right">
                        <p>right</p>
                        <p>right</p>        
                </div>
        </div>
</div>

CSS


.left{
        float:left;
        width:100px;
        position:relative;
}
.right-fix{
        float:right;
        width:100%;
        margin-left:-100px;
}
.right{
        margin-left:120px;
}

3、float+overflow

IE6下不支持这样的写法
HTML

<div class="parent">
        <div class="left">
                <p>left</p>     
        </div>
        <div class="right">
                <p>right</p>
                <p>right</p>        
        </div>
</div>

CSS


.left{
        float:left;
        width:100px;
        margin-right:20px;
}
.right{
        overflow:hidden;
}

4、table

table-layout:fixed可以提高渲染速度,布局优先
兼容性:只支持IE8及以上,因为IE6、7不支持table属性

HTML

<div class="parent">
        <div class="left">
                <p>left</p>     
        </div>
        <div class="right"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值