如果有一个DIV作为外部容器,内部的DIV如果设置了float样式,则外部的容器DIV因为内部没有 clear,导致不能被撑开。看下面的例子:
Div布局如下:

Css代码如下:
.out{border:1px solid #F00; width:500px;}
.inner1{width:200px; height:200px; float:left; border:1px solid #00F;}
.inner2{width:200px; height:200px; float:left; border:1px solid #0F0;}
IE和FF显示如下图:

传统的人解决方法:

但是,这么多加一个DIV有点不妥。一是多了一个没有意义的DIV,二是在用dojo做Drag & Drop的时候,由于这个DIV是容器DIV的一个字节点,如果这个节点被移动,则会造成排版上的Bug:如果要显示的蓝框的DIV被移到这个DIV之 后,则因为clear:both,它会被强制换一行显示。所以,最好使用下面clearfix方法。外层div加上clearfix样式。clearfix定义如下:
.clearfix:after{visibility:hidden;display:block;font-size:0;content: " ";clear:both;height:0;}
.clearfix{*zoom:1;}
这样修改以后显示正常。

那段代码是用来清除浮动的。
以下代码可以这么解释:
.clearfix:after {       <----在类名为“clearfix”的元素内最后面加入内容;
    content: ".";     <----内容为“.”就是一个英文的句号而已。也可以不写。
    display: block;   <----加入的这个元素转换为块级元素。
    clear: both;     <----清除左右两边浮动。
    visibility: hidden;      <----可见度设为隐藏。注意它和display:none;是有区别的。仍然占据空间,只是看不到而已;
    height: 0;     <----高度为0;
    font-size:0;    <----字体大小为0;
}
整段代码就相当于在浮动元素后面跟了个宽高为0的空div,然后设定它clear:both来达到清除浮动的效果。(这个css的原理是经过使用 after伪对象,它将在应用clearfix的元素结尾添加content中的内容,也就是一个".",并且把他设置为块级元素 (display="block");高度设置为0,clear="both",然后将其内容隐藏掉(visibility="hidden").这样就会撑开此块级元素.)

之所以用它,是因为,你不必在html文件中写入大量无意义的空标签,又能清除浮动。
.clearfix { *zoom:1;}   <----这是针对于IE6的,因为IE6不支持:after伪类,这个神奇的zoom:1让IE6的元素可以清除浮动来包裹内部元素。具体意思的话,不用深究,听说微软的工程师自己都无法解释清楚。height:1%效果也是一样。

clearfix的用法相关推荐

  1. css .clearfix,css之clearfix的用法深入理解(必看篇)

    如果有一个DIV作为外部容器,内部的DIV如果设置了float样式,则外部的容器DIV因为内部没有 clear,导致不能被撑开.看下面的例子: Div布局如下: Css代码如下: CSS Code复制 ...

  2. 前端基础-jQuery的事件的用法

    阅读目录 常用事件 事件绑定 移除事件 页面载入 一.常用事件 1.鼠标事件之click事件 用交互操作中,最简单直接的操作就是点击操作.jQuery提供了两个方法一个是click方法用于监听用户单击 ...

  3. matlab的compass怎么用,Compass用法指南

    几个月前,我介绍了Sass的用法. Sass是一种"CSS预处理器",可以让CSS的开发变得简单和可维护.但是,只有搭配Compass,它才能显出真正的威力. 本文介绍Compas ...

  4. [转]你所不知的 CSS ::before 和 ::after 伪元素用法

    SS 有两个说不上常用的伪类 :before 和 :after,偶尔会被人用来添加些自定义格式什么的,但是它们的功用不仅于此.前几天发现了 Creative Link Effects 这个非常有意思的 ...

  5. float 常见用法与问题--摘抄

    float 属性绝对是众多切图仔用的最多的 CSS 属性之一,它的用法很简单,常用值就 left.right.none 三个,但是它的特性你真的弄懂了吗? 我会在这里介绍我对 float 的认识与使用 ...

  6. 解读浮动闭合最佳方案:clearfix

    之前给大家介绍两种浮动闭合的办法 ,得知很多同学都在使用下面的骨灰级解决办法: .clear{clear:both;height:0;overflow:hidden;} 上诉办法是在需要清除浮动的地方 ...

  7. phppage类封装分页功能_PHP封装的page分页类定义与用法完整示例

    本文实例讲述了PHP封装的page分页类定义与用法.分享给大家供大家参考,具体如下: 亲测有效,见下图=========> 1. 测试实例test.php header("Conten ...

  8. javascript中setInterval,setTimeout的区别跟用法

    setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式. setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭. se ...

  9. ::before 和 ::after 伪元素用法

    CSS 有两个说不上常用的伪类 :before 和 :after,偶尔会被人用来添加些自定义格式什么的,但是它们的功用不仅于此. 一 基本语法 在了解进阶的应用之前,先来了解一下语法规则.平常仅仅需要 ...

最新文章

  1. java map操作_Java 8 中的 Map 骚操作,学习下!
  2. Spring Cloud中Hystrix、Ribbon及Feign的熔断关系是什么?
  3. 什么是认证、授权、会话
  4. Silverlight 中datagrid控件-- 通过设置数据虚拟化加速显示
  5. Python机器学习库sklearn的安装
  6. java接口自动化demo_第一个java 接口自动化程序
  7. ZZULIOJ 1102: 火车票退票费计算(函数专题)
  8. Fluent Ribbon项目出现“命名空间“clr-namespace:Fluent;assembly=Fluent”中不存在“RibbonWindow”名称”的解决方法...
  9. java实现kmp_java 实现KMP算法
  10. 用jframe给MySQL输入数据_如何从JTextField输入Info到sql数据库?
  11. Tortoise SVN 如何汉化(最简单的处理方式,一看就会)
  12. 旧版sai笔刷_sai笔刷包最新下载
  13. Javaweb-学习路线
  14. Mac翻译系列软件推荐一:欧路词典 for Mac
  15. 三星note3 android7.0,#原创新人#小白刷机三星NOTE III吃上安卓7.0重生记
  16. win7关机快捷键_150个常用的电脑快捷键,你都知道算我输
  17. 完全平方数-xdoj
  18. java 数组总结(赋值,反转,添加,查找)
  19. excel文件保护工作表无法编辑,忘记密码时解决办法
  20. Android中使用Webview SSL 自签名CA证书安全校验方案

热门文章

  1. uniapp 下载文件(视频)
  2. 亚马逊买家号留不了评是怎么回事?
  3. 零售电子货架标签解决方案
  4. 【升级】专为小白设计的TypeScript入门课吾爱分享会须一饮三百杯
  5. 16.线程通信1:生产者/消费者问题
  6. 11.孩子被欺负了怎么办?
  7. 服务器连接github
  8. SharePoint 企业搜索-PowerShell
  9. 数据结构——栈(C语言)
  10. Java实现PDF导出功能