hasLayout定义

haslayout 是Windows Internet Explorer渲染引擎的一个内部组成部分。在Internet Explorer中,一个元素要么自己对自身的内容进行计算大小和组织,要么依赖于父元素来计算尺寸和组织内容。为了调节这两个不同的概念,渲染引擎采用 了 hasLayout 的属性,属性值可以为true或false。当一个元素的 hasLayout 属性值为true时,我们说这个元素有一个布局(layout)

当一个元素有一个布局时,它负责对自己和可能的子孙元素进行尺寸计算和定位。简单来说,这意味着这个元素需要花更多的代价来维护自身和里面的内容, 而不是依赖于祖先元素来完成这些工作。因此,一些元素默认会有一个布局。当我们说一个元素“拥有layout”或“得到layout”,或者说一个元素 “has layout” 的时候,我们的意思是指它的微软专有属性 hasLayout 被设为了 true 。一个“layout元素”可以是一个默认就拥有 layout 的元素或者是一个通过设置某些 CSS 属性得到 layout 的元素。如果某个HTML元素拥有 haslayout 属性,那么这个元素的 haslayout 的值一定只有 true,haslayout 为只读属性 一旦被触发,就不可逆转。通过 IE Developer Toolbar 可以查看 IE 下 HTML 元素是否拥有haslayout,在 IE Developer Toolbar 下,拥有 haslayout 的元素,通常显示为“haslayout = -1”。

负责组织自身内容的元素将默认有一个布局,主要包括以下元素(不完全列表):

  • <html>, <body>
  • <table>, <tr>, <th>, <td>
  • <img>
  • <hr>
  • <input>, <button>, <select>, <textarea>, <fieldset>, <legend>
  • <iframe>, <embed>, <object>, <applet>
  • <marquee>

对于并非所有的元素都默认有布局,微软给出的主要原因是“性能和简洁”。如果所有的元素都默认有布局,会对性能和内存使用上产生有害的影响。

激发hasLayout

大部分的 IE 显示错误,都可以通过激发元素的 haslayout 属性来修正。可以通过设置 css 尺寸属性(width/height)等来激发元素的 haslayout,使其“拥有布局”。如下所示,通过设置以下 css 属性即可。

  • position : absolute
  • float : left | right
  • display : inline-block
  • width : 任何值除了auto
  • height : 任何值除了auto
  • writing-mode : tb-rl
  • zoom : 任意值除了normal

IE7还有一些属性可以触发hasLayout属性:

  • overflow : hidden | scroll | auto
  • overflow-x|-y : hidden | scroll | auto
  • position : fixed
  • min-width|-height : 任意值除了none
  • max-width|-height : 任意值除了none

其中 overflow-x 和 overflow-y 是 css3 盒模型中的属性,目前还未被浏览器广泛支持。

对于内联元素(默认即为内联的元素,如 span,或 display:inline; 的元素),

  • width 和 height 只在 IE5.x 下和 IE6 或更新版本的 quirks 模式下触发 hasLayout 。而对于 IE6,如果浏览器运行于标准兼容模式下,内联元素会忽略 width 或 height 属性,所以设置 width 或 height 不能在此种情况下令该元素具有 layout。
  • zoom 总是可以触发 hasLayout,但是在 IE5.0 中不支持。

具有“layout” 的元素如果同时 display: inline ,那么它的行为就和标准中所说的 inline-block 很类似了:在段落中和普通文字一样在水平方向和连续排列,受 vertical-align 影响,并且大小可以根据内容自适应调整。这也可以解释为什么单单在 IE/Win 中内联元素可以包含块级元素而少出问题,因为在别的浏览器中 display: inline 就是内联,不像 IE/Win 一旦内联元素拥有 layout 还会变成 inline-block。

重置hasLayout

将下列属性修改为它们的默认值,可以重置hasLayout属性。

  • width | height : auto
  • max-width|-height : none (IE7)
  • position : static
  • float : none
  • overflow : visible (IE7)
  • zoom : normal
  • writing-mode : lr-tb

display : inline-block属性设置了hasLayout=true时,即使采用display:block|inline覆盖这个属性,hasLayout也不会被重置为false。

把 mid-width, mid-height 设为它们的默认值”0″仍然会赋予 hasLayout,但是 IE 7 却可以接受一个不合法的属性”auto”来重置 hasLayout。

hasLayout常见问题

hasLayout对容器显示的影响是很难预见的。

  1. 常见IE浮动的bugs
  2. 容器本身解析基本属性的差异
  3. 容器和其后代之间的外边距塌陷
  4. 各种与list相关的问题
  5. 背景图片定位的偏差
  6. 浏览器解析脚本的差异

当网页在 IE 中有异常表现时,可以尝试激发 haslayout 来看看是不是问题所在。常用的方法是给某元素 css 设定 zoom:1 。使用 zoom:1 是因为大多数情况下,它能在不影响现有环境的条件下激发元素的 haslayout。而一旦问题消失,那基本上就可以判断是 haslayout 的原因。然后就可以通过设定相应的 css 属性来对这个问题进行修正了。建议首先要考虑的是设定元素的 width/height 属性,其次再考虑其他属性。

对 IE6 及更早版本来说,常用的方法被称为霍莉破解(Holly hack),即设定这个元素的高度为 1% (height:1%;)。需要注意的是,当这个元素的 overflow 属性被设置为 visible 时,这个方法就失效了。或者使用 IE 的条件注释。

对 IE7 来说,最好的方法时设置元素的最小高度为 0 (min-height:0)。

hasLayout常见bug的处理:

IE6 及更低版本的双空白边浮动 bug

bug 修复: display:inline;

IE5-6/win 的 3 像素偏移 bug

bug 修复: _height:1%;

E6 的躲躲猫(peek-a-boo) bug

bug 修复: _height:1%;

css hacks:

针对IE7和它以前的版本,以下hack已经得到验证。

John Gallant 和 Holly Bergevin在2003年发布了这个Holly hack:

/* \*/

* html .gainlayout { height: 1%; }

/* */

除了IE6下的标准模式里的行内元素,在IE5-6的所有版本里,这个hack都会触发所有元素的layout;

除了某些极稀少的height:0或者1px,它通常工作的很好;

除了在IE6的标准模式下(height:1%转化为height:auto,除非它的父元素有一个明确的高度),其他都与overflow:hidden是不相容的;

在IE7的标准模式下*html不会选择任何一个元素,它是没有任何效果的;

给IE6以及它以下的版本layout,也可以用这个underscore hack:

.gainlayout { _height: 0; }

针对IE7,可以用min-hight属性:

.gainlayout { min-height: 0; }

还可以采用conditional comments:

<!–[if lte IE 6]>
<style>
.gainlayout { height: 1px; }
</style>
<![endif]–>

<!--[if IE 7]>

<style>

.gainlayout { zoom: 1; }

</style>

<![endif]-->

通过浏览器检测,来引入修复hasLayout bug的样式表,是比较简洁和可靠的解决办法:

<link rel="stylesheet" href="allbrowsers.css" type="text/css" />

<!--[if lte IE 7]>

<link rel="stylesheet" href="iefix.css" type="text/css" />

<![endif]-->

在IE6和它之前的版本,经常使用height:1%或者height:1px,但是在IE7标准模式下,设置height对行内元素无效,可以采用display:inline-block或者zoom:1。

避免采用*{_height:1px;},这样可能会影响元素基本的渲染和展示。

IE for Mac和IE for Windows分别拥有各自的渲染引擎,IE for Mac更接近标准模式,不采用hasLayout属性。

如果想得到一个更详尽的hasLayout触发和hasLayout在不同的IE版本里的比较的话,请参考这里:Thoughts on IE hack management.

参考文档:

http://www.qianduan.net/comprehensive-haslayout.html

http://www.satzansatz.de/cssd/onhavinglayout.html

http://www.jsann.com/post/ie_layout_detailed.html

转载于:https://www.cnblogs.com/linxuehan/p/3905207.html

IE hasLayout详解相关推荐

  1. haslayout详解

    定义 haslayout是IE7-浏览器的特有属性.hasLayout是一种只读属性,有两种状态:true或false.当其为true时,代表该元素有自己的布局,否则代表该元素的布局继承于父元素. [ ...

  2. 网页设计中的默认字体样式详解

    浏览器默认的样式往往在不同的浏览器.不同的语言版本甚至不同的系统版本都有不同的设置,这就导致如 果直接利用默认样式的页面在各个浏览器下显示非常不一致,于是就有了类似YUI的reset之类用来尽量重写浏 ...

  3. 详解CSS float属性

    转自:http://luopq.com/2015/11/08/CSS-float/ \详解CSS float属性 Posted on 2015-11-08   |   In CSS   |   5条评 ...

  4. CSS-高度塌陷布局乱问题详解

    文章目录 高度塌陷问题详解 1. 什么是高度塌陷 说明 2. 解决方法 2.1. 解决方法一 W3C 隐藏属性 说明 如何开启元素的 BFC 兼容性 ZOOM 2.2. 解决方法二(推荐) 清除浮动 ...

  5. CSS HACK收集:在IE6下hack的方法详解

    原文:http://www.html5cn.org/article-5027-1.html +  针对IE7 * 针对ie6和ie7 _ 针对ie6 最好采用条件注释的方法 本篇文章小编为大家介绍CS ...

  6. CSS-float浮动和高度塌陷问题详解

    文章目录 浮动float 1. float 基本属性 2. 环绕的float 3. float撑开内容 高度塌陷问题详解 1. 什么是高度塌陷 说明 2. 解决方法 2.1. 解决方法一 W3C 隐藏 ...

  7. 从命令行到IDE,版本管理工具Git详解(远程仓库创建+命令行讲解+IDEA集成使用)

    首先,Git已经并不只是GitHub,而是所有基于Git的平台,只要在你的电脑上面下载了Git,你就可以通过Git去管理"基于Git的平台"上的代码,常用的平台有GitHub.Gi ...

  8. JVM年轻代,老年代,永久代详解​​​​​​​

    秉承不重复造轮子的原则,查看印象笔记分享连接↓↓↓↓ 传送门:JVM年轻代,老年代,永久代详解 速读摘要 最近被问到了这个问题,解释的不是很清晰,有一些概念略微模糊,在此进行整理和记录,分享给大家.在 ...

  9. docker常用命令详解

    docker常用命令详解 本文只记录docker命令在大部分情境下的使用,如果想了解每一个选项的细节,请参考官方文档,这里只作为自己以后的备忘记录下来. 根据自己的理解,总的来说分为以下几种: Doc ...

最新文章

  1. 有源晶振和无源晶振的区别
  2. jQuery实现浮动层跟随页面滚动效果
  3. 点击一百万次(详解)——bugku
  4. 海康威视:增速超预期 调高盈利预测
  5. pythonpop方法桐柏到郑州大_python脚本之一键移动自定格式文件方法实例
  6. 高通固件解包IPQ6000固件解包
  7. STL之红黑树容器:set,hash_set,multiset,hash_map,multimap
  8. 腾讯视频下载下来的视频在哪里
  9. 醴陵市事业单位计算机类面试题目,2019年湖南株洲醴陵县事业单位面试题(9月22日)...
  10. 我用 Python 集齐了支付宝五福!
  11. 各地实时摄像头_你头顶的摄像头将变成有脑子的眼睛!亚马逊推出AWS Panorama,强监控时代来临?...
  12. 创业邦:谈谈 To B业务的机会
  13. qt制作一个简易的听小说工具
  14. oa系统是什么?如何使用企业oa办公系统?
  15. 十大机器学习算法(一)
  16. Google表格初学者指南
  17. JAVA多线程基础篇 4、可见性、有序性与Volatile
  18. 第4-8课:方块消除游戏
  19. 三线制PT100测正温(篇一)
  20. 工程经济在施工项目成本控制中应用

热门文章

  1. ipone6界面设计标准
  2. 纯JAVA实现雷电飞机大战<可本地联机>
  3. 因子分析(Factor Analysis)
  4. c#MVC文件(图片,word,excel,zip等)批量上传
  5. 光电探测器的噪声等效功率,NEP
  6. 详细讲解二极管的钳位电路和限幅电路
  7. APOLLO UDACITY自动驾驶课程笔记——感知、预测
  8. [附源码]JAVA毕业设计景区门票系统(系统+LW)
  9. 为什么路由器服务器无响应怎么回事啊,路由器服务器无响应怎么办
  10. java foxpro_面向对象的语言主要包括C、Java、VB、FoxPro、Python、R等。