1、HASLAYOUT

  首先,haslayout翻译成中文就是:有布局。

  所谓布局,指的是一个元素可以对本身和里边的元素进行尺寸计算和定位。这里只是谈IE6/7,据说微软之所以不是对所有元素默认有布局,是为了浏览器的性能和简洁--!

  常见的哪些元素在ie6/7上是有布局的呢?常见的列举下:

body,html,table/tr/th/td,img,input/button/file/select/textarea,frame

  所以对于div、span、p等等元素就可能会出现没有布局的情况,就是没对对自身和里边元素进行相应的定位计算,而是靠的其他一些或是继承或是默认的方式进行定位。对于这种情况,就要触发该元素的haslayout属性了,触发的的手段有:

// 对以下属性设值可触发haslayout
zoom: (除 normal 外)
float: (非空)
position: absolute
display: inline-block
//块级元素的触发 
width/height: (除auto外)

  ie7还有其他的一些触发方法,没必要一一列举了。

  最常用的是zoom:1;因为设置这个一般不会影响其他属性,当然,有时候比如对块级你用width或是height属性已经触发了haslayout,就没必要多此一举的设zoom了。

  举个常见的例子,e.g:

  比如要设个内联元素为inline-block,ie6、7的原理是触发haslayout让内联元素可以设宽高和计算布局等,所有用zoom也是一样可以代替的。注意的是width/height属性只是块级元素才有的属性,内联元素会直接忽视他们,所有会触发不了。所以可以这么说,ie6/7本身是没有对inline-block设置特有的属性,只是把这个属性增加到触发haslayout的行列而已。这就是为什么block设个inline-block是没有效果的,只是触发haslayout而已,并不会内联。因此对于ie6/7的做法是先设为内联,再触发布局,模拟出inline-block的效果,不过还是有些许的区别,这样模拟后元素之间是没有间隙的。代码如下:

//ie6/7的块级元素inline-block的实现
display: inline;
*zoom: 1;

  好像有点罗嗦,不知道讲清楚没有,要做到兼容各个浏览器,你就可以根据ie6/7的原理用最少的代码兼容实现inline-block的效果。具体代码想必没必要写了,要不自行google一下inline-block的兼容ie6/7的代码就知道了。记住则己所需。

2、BFC

  还是先翻译下,即是block formatting contexts的缩写,翻译过来是:块级格式化上下文。以下说的都是非ie6/7的,因为ie6/7已经有专属的haslayout了,是不支持BFC的。

  什么是BFC,从字面意义上不好理解,所以还是直白去理解就最好了。干脆了解下这个到底做什么用的吧,如下:

  1、阻止子元素与外界的边距叠加。e.g:

//去掉触发的overflow试试
<div style="margin-bottom:10px;">123</div>
<div style="/*overflow:hidden*/">
<div style ="margin-top:10px;">321</div>
</div>

  2、BFC包容浮动,不会让浮动子元素越界。e.g:

//去掉触发的overflow试试
<div style="backgroun:red;/*overflow:hidden;*/">
<img style="float:left;" src="123.jpg">
<p>your ... text</p>
</div>

  3、BFC本身不会与外界的浮动重叠。 e.g:

//去掉触发的overflow试试
<div class="clearfix">
<img style="float:left;" src="123.jpg">
<p style="width:200px; background:red;/*overflow:hidden;*/">your ... text</p>
</div>

  所以从特性上讲,BFC就是一个不让内部元素与外界相互影响,包容浮动子元素,并自身和外界的浮动盒子不重叠的盒子。就是爱其子,且又洁身自爱,不像正常的婊子。

  能触发BFC的属性不多,常见的如下:

//触发BFC
float:(非空)
overflow: (非visible)
position: (absolute/fixed)
display: (inline-block)

  最常用的是overflow:hidden;理由和之前的zoom一样,这样一般不会影响到其他属性。

  注意的是,设置diplay:table就可以产生anonymous boxes,其中有可触发的display:table-cell属性,从而间接触发BFC。

  总结:ie6/7的haslayout和其他的BFC各显神通,不免会引起对比,通过触发的常用条件,不难发现,以下是可以同时触发haslayout和BFC的:float(非空)/position(absolute)/inline-block,区别肯定也是有的,比较明显的是haslayout是可以设置width/height的,BFC则不一定了,其他一些细微之处就不一一深究了,毕竟不同的浏览器渲染的方式总是不太一样的。

  最后,举个最最常用的例子做个结尾吧,刚好都有haslayout和BFC的使用,它就是我们可爱的清除浮动,细细看下吧:

.clearfix:before,
.clearfix:after {
  content: "";
  display: table; //here!
}
.clearfix:after {
  clear: both;
}
.clearfix {
  *zoom: 1;//here!
}

更多详情,可参考:http://www.smallni.com/haslayout-block-formatting-contexts/

以上是个人通过各个技术网站博客的探索实践中的一些总结,如有任何错误,还请务必指出。

实践中总结——理解haslayout和BFC的更多相关文章

  1. hasLayout与BFC的触发条件

    hasLayout与BFC是分别在IE和其他浏览器上的两个作用很相近的概念,在很多时候,我们需要触发它们去实现有些效果.例如清除浮动时需要触发hasLayout与BFC:很多自适应的两栏和三栏布局(两 ...

  2. 编程实践中C语言的一些常见细节

    对于C语言,不同的编译器采用了不同的实现,并且在不同平台上表现也不同.脱离具体环境探讨C的细节行为是没有意义的,以下是我所使用的环境,大部分内容都经过测试,且所有测试结果基于这个环境获得,为简化起见, ...

  3. 更加直观地了解hasLayout和BFC

    网络上有很多关于hasLayout和BFC相关的文章,但是大部分都显得有些晦涩难懂.所以想用一些比较直观的例子来说明hasLayout和BFC给平时的布局带来的影响. 基础知识 在讲hasLayout ...

  4. OpenStack实践系列⑦深入理解neutron和虚拟机

    OpenStack实践系列⑦深入理解neutron和虚拟机 五.深入理解Neutron 5.1 虚拟机网卡和网桥 [root@node1 ~]# ifconfig brq65c11cc3-8e: fl ...

  5. CSS学习(二)- 有关 hasLayout 和 BFC

    1. hasLayout 概念说明 ‘Layout’ 可以被某些 CSS property(特性)不可逆的触发,而某些 HTML 元素本身就具有 layout . ‘Layout’ 在 IE 中可以通 ...

  6. 03--(二)编程实践中C语言的一些常见细节

    编程实践中C语言的一些常见细节(转载) 对于C语言,不同的编译器采用了不同的实现,并且在不同平台上表现也不同.脱离具体环境探讨C的细节行为是没有意义的,以下是我所使用的环境,大部分内容都经过测试,且所 ...

  7. 阿里巴巴 Kubernetes 应用管理实践中的经验与教训

    作者 | 孙健波(阿里巴巴技术专家).赵钰莹 导读:云原生时代,Kubernetes 的重要性日益凸显.然而,大多数互联网公司在 Kubernetes 上的探索并非想象中顺利,Kubernetes 自 ...

  8. .NET Core 多框架支持(net45+netstandard20)实践中遇到的一些问题总结

    .NET Core 多框架支持(net45+netstandard20)实践中遇到的一些问题总结 前言 本文主要是关于.NET Standard 代码 在多框架 和 多平台 支持自己实践过程中遇到的一 ...

  9. Scrum 敏捷实践中的三大角色

    在我过去的近两年工作中,我们一直在应用 Scrum 敏捷项目管理方法来开展工作,今天,我先从它的角色划分来讲起,毕竟这可是它最鲜明的特征. 首先,为什么这种项目管理方法叫 Scrum ? Scrum ...

随机推荐

  1. 开发并调试 Mail Add-in

    开发并调试 Mail Add-in (mail app for Outlook) 准备工作 如果你的邮箱搭建在 Exchange Server 上,则可以创建邮件应用程序(Mail Add-in)来扩 ...

  2. IBM Java架构师的技能

    一天,群里飘过一个IBM招聘信息.我看过之后,也只是如此而已. 大家好!我是XXX,IBM招聘java架构师,如今还有38个名额 学历大专以上即可,英语能面试交流的.项目有非常多到时候依据您面试会详谈 ...

  3. User、Role、Permission数据库设计ABP

    ABP 初探 之User.Role.Permission数据库设计 (EntityFramework 继承的另一种使用方法) 最近群里(134710707)的朋友都在讨论ABP源码,我把最近学习的内容 ...

  4. HBase加Solr

    HBase加Solr 如何解决分布式系统数据事务一致性问题 (HBase加Solr) 摘要:对于所有的分布式系统,我想事务一致性问题是极其非常重要的问题,因为它直接影响到系统的可用性.本文以下所述所要 ...

  5. 面向对象三大特征之多态——Java笔记(七)

    多态:     同一个实体同时具有多种形式     编译时的类型有声明该变量时使用的类型决定,运行时的类型有实际赋值给变量的对象决定     如果编译时类型和运行时类型不同,就出现多态 例: clas ...

  6. Visual Studio 2010/2013 查看DLL接口(函数)

    1. “应用程序" Visual Studio 2010/2013 的Visual Studio Tools文件夹中打开Visual Studio Command Prompt 命令提示窗口 ...

  7. ProgressDialog(四)——更改系统自带ProgressDialog文字大小

    MainActivity如下面: package com.example.ttt; import android.app.Activity; import android.app.ProgressDi ...

  8. axure团队合作开发原型图

    谁是人画或其他原型图的头,但在基本制度的发展时,.我们分配一些人画的原型,其他部分干. 再画一个原型不再是一个人画,一起画,假设大家都各自画自己那一部分.最后再由一个人来整合的画.是非常麻烦. 咱平时 ...

  9. FindBugs:Compiler output path for module can not be null. check your module/project settings问题原因

    这可能是很多人在使用Android studio 该插件会发现此错误信息:Compiler output path for module can not be null. check your mod ...

  10. JAVA进阶-注解

    注解元数据分为4部分分别为Target,Documented,Inherited,Retention: Target>指定被注解的注解仅仅能使用在某个类型上;ElementType指定其类型:能 ...