第一种方法:结尾处加空div标签 clear:both
优点:这种方法兼容性好
缺点:但是有多余的标签
第二种方法:使用 :after 为元素
原理:IE8以上和非IE浏览器才支持:after,zoom(IE转有属性)可解决ie6,ie7浮动问题
优点:浏览器支持好、不容易出现怪问题(目前:大型网站都有使用,如:腾迅,网易,新浪等等) 缺点:IE8以上和非IE浏览器才支持:after建议:推荐使用,建议定义公共类,以减少CSS代码。
第三种:父级div定义 overflow:hidden 或是auto
原理:必须定义width或zoom:1,同时不能定义height,使用overflow:hidden时,浏览器会自动检查浮动区域的高度
优点:简单、代码少、浏览器支持好 缺点:不能和position配合使用,因为超出的尺寸的会被隐藏。 建议:只推荐没有使用position或对overflow:hidden理解比较深的朋友使用。
第四种:给父元素定高
原理:父级div手动定义height,就解决了父级div无法自动获取到高度的问题。
优点:简单、代码少、容易掌握 缺点:只适合高度固定的布局,要给出精确的高度,如果高度和父级div不一样时,会产生问题 建议:不推荐使用,只建议高度固定的布局时使用
参考:https://segmentfault.com/a/1190000003937063