• 两列float引起的父容器高度失效的解决办法


    解决子块float浮动后 父块高度自适应问题
    2008-05-02 00:46
    也许你在做网页的时候发现,发一个区块内的元素被应用了float之后,那么整个box的高度对就不以被浮动对象的高度为标准了。
    如图中的城市导航内的城市列表中采用了float之后,那个外框的高度并不是内容元素的高度:

    怎么解决这个问题呢?经发现可以采用overflow来解决!方法是在父元素加上
    overflow:auto; zoom:1;

    即可
    overflow:auto;是让高度自适应, zoom:1;是为了兼容IE6,也可以用height:1%;的方式来解决。

    示例代码开始

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>float浮动之后的问题</title>
    <style>
    * { padding:0; margin:0;}
    body { font-size:12px; line-height:150%;}
    ul { list-style:none;}
    .container { 700px; margin:0 auto;}
    .header, .footer { height:60px; background:#99CC66; margin-bottom:6px; font-size:18px; font

    -weight:bold;}
    .main {}
    .left { float:left; 200px;}
    .sidepanel { border:1px solid #CC6600; margin-bottom:8px;}
    .sidepanel h2 { font-size:12px; background:#CC6600; height:24px; line-height:24px; text-

    indent:20px; color:#fff;}
    .city { padding:6px 0px; overflow:auto; zoom:1;}
    .city li { float:left; 35px; text-align:center;}
    .right { margin-left:200px; background:#CCCC66; height:240px;}
    .hotinfo {padding:6px;}
    .clearfloat {clear:both;height:0;font-size: 1px;line-height: 0px;}
    </style>
    </head>

    <body>
    <div class="container">
    <div class="header">header</div>
    <div class="main">
        <div class="left">
          <div class="sidepanel">
            <h2>城市导航</h2>
            <ul class="city">
              <li>北京</li>
              <li>上海</li>
              <li>天津</li>
              <li>南京</li>
              <li>广州</li>
              <li>重庆</li>
              <li>济南</li>
              <li>杭州</li>
              <li>郑州</li>
              <li>北京</li>
              <li>上海</li>
              <li>天津</li>
              <li>南京</li>
              <li>广州</li>
              <li>重庆</li>
              <li>济南</li>
              <li>杭州</li>
              <li>郑州</li>
            </ul>
          </div>
          <div class="sidepanel">
            <h2>热门文章</h2>
            <ul class="hotinfo">
              <li>本月20日起入境日本须留指纹</li>
              <li>本月20日起入境日本须留指纹</li>
              <li>本月20日起入境日本须留<font color="#43FF73">指纹</font></li>
              <li>本月20日起入境日本须留指纹</li>
              <li>本月20日起入境日本须留指纹</li>
              <li>本月20日起入境日本须留指纹</li>
              <li>本月20日起入境日本须留指纹</li>
              <li>本月20日起入境日本须留指纹</li>
              <li>本月20日起入境日本须留指纹</li>
            </ul>
          </div>
        </div>
        <div class="right">右侧内容</div>
    </div>
    <br class="clearfloat" /><!-- 用于清除浮动的元素 -->
    <div class="footer">footer</div>
    </div>
    </body>
    </html>

    示例代码结束

    另一种方法如下,上面的较易实现

    我们在写 CSS 的时候经常会遇到这样的情况:一个 div#Main 框架内包含 div#Left 和 div#Right,由于左右需要平行,所以我们会写如 CSS 文件里 float:left;、float:right 这样的语句。

    而如果 div#Main 又定义了 y 轴循环的背景的话,在老版本的 IE 里是没问题的,但是在其它浏览器以及 IE7 之后的版本中,会出现背景只循环了一小部分。为什么呢?因为在子层应用了漂浮层(float)的话,就会导致 div#Main 的高度失效。怎么解决呢?一般的初学者可能会认为加个 clear:both; 在父层(div#Main)就可以完事了。但是事情不是这样的!高度依然不生效。下面我介绍一下这种情况的解决办法。

    在定义了漂浮层的父级定义绝对的宽(width)和高(height)。这里注意一下,并不是只可以用像素~用百分比也是可以的!假如 div#Left 和 div#Right 的 CSS 如下:

    CSS代码
    1. #Left {
    2.     float:left;
    3.     width:30%;
    4.     height:100%;
    5. }
    6. #Right {
    7.     float:right;
    8.     width:70%;
    9.     height:100%;
    10. }

    那么,div#Main 的 CSS 就要加上以下的语句:

    CSS代码
    1. #Main {
    2.     float:left;
    3.     /*或者 float:right*/
    4.     width:100%;
    5.     height:100%;
    6.     /*用了 padding 的最好是定义绝对的像素(px)*/
    7. }

    这样一来,div#Main 的高就可以随着 div#Left 或 div#Right 的最大高度而延伸了。

  • 相关阅读:
    Boost Log : Log record formatting
    Boost Log : Attributes
    PLSA的EM推导
    特征处理:一点经验
    海量推荐系统:mapreduce的方法
    操作系统之存储器管理
    maredit测试
    算法:链表
    c++特别要点:多态性与虚函数
    sizeof的用法与字节对齐
  • 原文地址:https://www.cnblogs.com/200325074/p/1432770.html
Copyright © 2020-2023  润新知