IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    css使用float溢出问题

    jakes发表于 2015-03-24 11:51:49
    love 0

    一、使用float的弊端

    浮动 Floats 是 CSS 中的一种布局方式。它的渲染位置在行框与包含块之间,这样就可以使行框内文字与浮动元素不重叠并且环绕它显示。在布局过程中也经常会使用它来达到左右并排布局的效果。但是,由于浮动特性,容器如果没有明确设定高度,会依照普通流内元素高度设置,这样就会导致脱离普通流的浮动元素溢出容器,影响其后元素布局。

    举例如下:

    
    
        
        Document
                
    
    
        
    我是浮动元素

    我和浮动元素在同一个div

    可以看到浮动元素已经能够超出了div,并盖住了我

    效果:

    133122_lOWH_1243330

    二、清除float溢出的方法

    1.使用 clear 样式清除

    .clear-float {clear:both;}

    clear 属性是 CSS 1 就提供的用来清除浮动的样式,设置了 clear 属性的元素,其上边框位置会紧贴浮动元素的 margin-bottom 边界位置渲染,忽略其 margin-top 设置。这样,父容器高度未设定(值是 auto)时,由于定义的清理浮动样式元素所在位置处于浮动元素之下,容器计算后的实际高度就包含了浮动元素。

    2.使用伪元素 :after 清除

    .after-clear-float :after{content:””; display:block; clear:both;}

    :after 伪元素是在 CSS 2 规范内提出的,IE 6/7 并不支持。它的作用是在指定该伪元素元素内,所有子元素最后自动生成一个伪元素,并可以为这个伪元素设定样式。在设定样式中,使用 clear 属性即可达到与手工添加元素指定清理的效果。

    3.使用 overflow 清除

    .overflow-clear-float {overflow:hidden;}
    或者
    .overflow-clear-float {overflow:auto;}

    overflow 样式值为 非 visilbe 时,实际上是创建了 CSS 2.1 规范定义的 Block Formatting Contexts。创建了它的元素,会重新计算其内部元素位置,从而获得确切高度。这样父容器也就包含了浮动元素高度。这个名词过于晦涩,在 CSS 3 草案中被变更为名词 Root Flow,顾名思义,是创建了一个新的根布局流,这个布局流是独立的,不影响其外部元素的。实际上,这个特性与 早期 IE 的 hasLayout 特性十分相似。IE6/7不支持。

    4.使用 display:table 清除

    .table-clear-float {display:table}
    或者
    .table-clear-float {display:table-cell}

    当元素 display 值被设定为 table 或 table-cell 时,同样也创建了 CSS 2.1 规范定义的 Block Formatting Contexts。这样父容器也就包含了浮动元素高度。所以同样不支持IE6/7。

    三、避免使用float,用更好的方法处理

    1.无序链接

    经常可以看到一些网站的关键字链接,或者产品关键字,已经分类等部分会用到比较短的链接混乱排列,有些人使用

    • 配合float来做链接,我想这个是完全没有必要的,你可以设定
    • 标签的display:inline,把
    • 设定为线级元素来达到混排的效果,不需要使用float。甚至这样的 链接完全可以由

      这样的标签来代替,岂不是更简洁?

      2.右端元素

      我们在做一个区块的时候经常使要用more(更多)来链接相关的页面,这样的标题栏往往左边是标题,右边为more链接,很多人喜欢用 float来做,这样在float之后还要多一个标签来clear,感觉很繁琐,甚至更有人用整张图片配合热点来做,我觉的这些都不是很好的办法。其实像这种效果完全可以用定位来做,设定title的position:relative。然后定义more这个标签的right:0等更详细的设定它的位置。这样省去了float以及clear,结构也更清晰了。

      3.多列不规则布局

      我们经常要用到3列布局,这种布局由于规则,但是为了美观,我们必须定义3列的总宽度,但是根据CSS中浮动的总宽必须<99%的父标签宽度,否则经常会在某些浏览器下出错,但是99%的宽在宽屏显示器下面很明显会出现10px以上的错位,所以这是一个很郁闷的 问题,其实在碰到这类问题时我们应该有限使用position定位来解决问题,而不是浮动,这个问题在这里就不多说了,下面会有一篇关于定位的详细文章。

      参考:
      http://w3help.org/zh-cn/casestudies/001
      http://www.cnblogs.com/showker/archive/2010/05/22/1741477.html



沪ICP备19023445号-2号
友情链接