子Div使用Float后如何撑开父Div

一个Div包含了多个子Div,并且子Div使用了浮动后,父Div确不能被撑开,如下图:



部分代码如下:

<style>
  #div1{border:1px solid red;float:left;}
  #div2,#div3{float:right;border:1px solid blue;}
</style>

<div id="div1">
  <div id="div2">two</div>
  <div id="div3">one</div>
</div>

如果想要撑开父元素可以采用以下方法:
方法一:父元素设置overflow以及zoom,样式如下:

<style>
 #div1{border:1px solid red;overflow:hidden;zoom:1;}
  #div2,#div3{float:right;border:1px solid blue;}
</style>

方法二:父元素也是设置浮动效果,样式如下:

 <style>
#div1{border:1px solid red;float:left;}
 #div2,#div3{float:right;border:1px solid blue;}
</style>

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

方法三:在添加一个子元素,并设置clear样式:

<div id="div1">
<div id="div2">two</div>
<div id="div3">one</div>
<div style="clear:both"></div>
</div>

此方法添加了一个div元素,有些情况下可能这个div会影响元素的遍历。

以上方法 使用doctype html 4.0 以及 doctype xhtml 1.0 的 Transitional 在FF IE6 IE7 IE8 Chrome Safari下测试通过,其他浏览器没有测试。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,687评论 1 92
  • 前端开发面试知识点大纲: HTML&CSS: 对Web标准的理解、浏览器内核差异、兼容性、hack、CSS基本功:...
    秀才JaneBook阅读 7,466评论 0 25
  • 转载请声明 原文链接地址 关注公众号获取更多资讯 第一部分 HTML 第一章 职业规划和前景 职业方向规划定位...
    前端进阶之旅阅读 16,704评论 32 459
  • <a name='html'>HTML</a> Doctype作用?标准模式与兼容模式各有什么区别? (1)、<...
    clark124阅读 8,938评论 1 19
  • 20160718 我:我爱你! 小暖男:妈妈不要爱毕毕! 我:妈妈爱毕毕,你爱妈妈吗? 小暧男:毕毕不要爱妈妈! ...
    米勒Li阅读 2,924评论 0 0