html div自动高度,CSS技巧:3种常用方法解决div列高度自适应

本文向大家介绍一下解决div列高度自适的3种常用方法,分别是利用“clear:both”背景填充,使用脚本控制高度和margin负值父子容器高度继承三种。

CSS技巧:解决div列高度自适的3种常用方法

解决div列高度自适的方法有很多种,这里介绍三种最常用的方法给大家(下面所有例子以父main,子divleft、divright为例)。

1、利用“clear:both”背景填充(推荐!!!)

这是使用最广泛的一种做法,我一直都用此方法解决div列高度自适问题。三行二列布局,主要内容在右边,网页宽度780px,左列240px,右列540px。

CSS代码:

#main{

width: 780px;

margin: 0;

background: url(bg.gif) #FFFFFF repeat-y left;

text-align: left;

}

#divleft{

float: left;

width: 240px;

}

#divright{

float: right;

width: 540px;

}

.clear{

border-top:1px solid transparent !important;

margin-top:-1px !important;

border-top:0;

margin-top:0;

clear:both;

visibility:hidden;

}

html代码:

div>

div>

div>

div>

优点:无hacks,完全的自适应高度。

2、脚本控制高度 ..

在中加入如下代码(假设divright的高度相对***):

document.getElementById"divleft").style.height

=document.getElementById"divright").scrollHeight "px"

script>

优点:代码超级简单

缺点:要确定有某一列的高度始终是相对***的,此方法比较被动。

3、margin负值父子容器高度继承

这个方法能较好地解决列高度相同的问题。三行二列布局,主要内容在左边,网页宽度780px,左列540px,右列240px。

CSS代码:

#main{

width: 540px;

float:left;

background:#FFFFFF;

text-align:left;

}

#divleft{

width: 540px;

float: left;

position:relative;

margin-left:-540px;

}

#divright{

width: 240px;

float: right;

position:relative;

margin: 0 -240px 0 0;

background: #F0F0F0;

}

html代码:

div>

div>!

div>

或许刚接触的Web Standards的朋友对这种方法不怎么理解,现Blank分析一下:

[A]

[B][C]

上结构中a包含c,c包含b。当b的高度为***时,那么a和c将继承b的高度,如果a和b位置重合,将显示b的背景;而当c的高度***时,那么a继承将继承c的高度,如果a和b位置重合,将显示a的背景。这样无论b***或者c***都将显示div列高度相同。

优点:兼有***种方法的优点,并且比***种方法的代码稍微简洁。

缺点:整体结构只能左对齐。

【编辑推荐】

【责任编辑:程华权 TEL:(010)68476606】

点赞 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值