首页 > 开发 > CSS > 正文

详解IE浏览器的haslayout属性及相关兼容性问题解决

2024-07-11 08:32:42
字体:
来源:转载
供稿:网友

IE,这个令所有网站设计人员讨厌,但又不得不为它工作的浏览器。不论是6、7还是8,它们都有一个共同的渲染标准haslayout,所以haslayout 是一个非常有必要彻底弄清除的概念。大多 数IE下的显示错误,就是源于它。

什么是Layout呢?
"Layout" 是 IE 的一个私有属性,并不是W3C标准。它决定了一个对象(就是一个标签div、li等)在内容中如何显示、与周围对象的位置关系、以及怎样响应程序或用户产生的事件。

这个属性可以被一些css强制激活。一些HTML标签默认具有haslayout。
PS:一个对象的layout属性被激活,它的具体表现就是haslayout=true。我们可以用IE Developer Toolbar工具看到被激活的对象带有"haslayout = -1"的属性。

下面这些标签默认拥有haslayout属性:

XML/HTML Code复制内容到剪贴板
  1. <html>, <body>   <table>, <tr>, <th>, <td>  
  2. <img>   <hr>  
  3. <input>, <button>, <select>, <textarea>, <fieldset>, <legend>   <iframe>, <embed>, <object>, <applet>  
  4. <marquee>  

你可能就问:微软干嘛要设layout这个东西呢?当一个对象的layout被激活时,它以及它的子对象的定位和尺寸计算将独立进行,不受附近对象 的干扰。也就是说它拥有一个独立的布局(layout)。因此浏览器要花费更多的代价来处理拥有haslayout的对象。为了提高性能,微软增加了 layout这个IE私有的概念。

怎样激活layout?
下面列出的css属性可以激活对象的layout:

CSS Code复制内容到剪贴板
  1. position: absolute  

设置绝对定位可能会引发新的问题。

CSS Code复制内容到剪贴板
  1. float: left|rightright  

IE下的浮动也会产生一些莫名其妙的问题。

CSS Code复制内容到剪贴板
  1. display: inline-block  

当一个内联元素需要haslayout属性时就需要用它,但是IE本身不支持inline-block的,只是表现得像标准里说的inline-block。
1.width: 除'auto'外的任意值
优先考虑使用该属性。
2.height: 除'auto'外的任意值
对 IE6 及更早版本来说很常用,该方法被称为霍莉破解(Holly hack),即设定这个元素的高度为 1% (height:1%;)。但是要注意,当这个元素的 overflow 属性被设置为 visible 时,这个方法就失效了。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表