Div+CSS布局常见问题

1.父元素不设置高度,子元素应用float属性,会造成父元素高度坍塌的问题,不能实现高度自适应

分析:浮动float属性会使得元素脱离当前HTML文档流,那么会使得:当前HTML文档会当作设置float属性的元素不存在一样。那么,由于这5个子元素都设置了float,所以可以看作父元素#container内根本没有内容,div在没内容的时候表现正好是高度=0.

解决办法:

a.设置父元素float

例如:

#container {

background-color: #f1f1f1;

width: 80%;
margin: 20px auto;
float: right;
}  这样,父元素也是脱离当前文档流,子元素和父元素一起脱离,并且子元素仍在父元素内,父元素内容不空了,所以高度会适应子元素高度。

此方法有个缺陷是,父元素的宽度需要设置。

b.在最后一个设置浮动的子元素后加一个空div  ,并且让这个div清除浮动。ps:在元素遍历的时候会出现问题

c.父元素设置overflow:hidden;zoom:1;



2.多个div嵌套时,子Div的margin-top不起作用

原因:盒子没有获得 haslayout  造成 margin-top无效
解决办法:

1、在父层div加上:overflow:hidden;

2、把margin-top外边距改成padding-top内边距 ;

3、父元素产生边距重叠的边有不为 0 的 padding 或宽度不为 0 且 style 不为 none 的 border。

    父层div加: padding-top: 1px;


4、让父元素生成一个 block formating context,以下属性可以实现
    * float: left/right
    * position: absolute
    * display: inline-block/table-cell(或其他 table 类型)
    * overflow: hidden/auto
   父层div加:position: absolute;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值