ie6 position约对定位错位解决办法

  次阅读 作者:智能小宝 来源:互联网 2016-03-25 16:16 我要评论(0)

ie6绝对定位的bug及其解决办法。position:absolute定位在ie6下存在left和bottom的定位错误问题

ie6中很多bug都可以通过触发layout得到解决,以上的解决方法无论是设置zoom:1还是设置width和height其实都是为了触发layout。下列的css教程属性或取值会让一个元素获得layout:

position:absolute 绝对定位元素的包含区块(containing block)就会经常在这一方面出问题

float:left|right 由于layout元素的特性,浮动模型会有很多怪异的表现

display:inline-block 当一个内联级别的元素需要layout的时候就往往符用到它,这也可能也是这个css属性的唯一效果—-让某个元素有layout

width: 除auto外的任何值

height: 除auto外的任何值

zoom: 除auto外的任何值

代码如下

复制代码

<!–ie6下的bottom定位错误–>

<hr />

<div style=”position:relative;border:1px solid orange;text-align:center;”>

<a href=”http://www.111cn.net”>http://www.111cn.net/</a>

<div style=”position:absolute;bottom:0;left:0;background:#ccc;”></div>

</div>

这段代码在ie6下,bottom定位错误:解决办法和left定位类似:

方法1是给父层设置zoom触发layout。

方法2是给父层设置高度(height)。

<!–解决方法1 zoom:1–>

<hr />

<div style=”position:relative;border:1px solid orange;zoom:1;text-align:center;”>

<a href=”http://www.111cn.net”>http://www.111cn.net/</a><br />

<a href=”http://www.111cn.net”>http://www.111cn.net/</a>

<div style=”position:absolute;bottom:0;left:0;background:#ccc;”></div>

</div>

<!–解决方法2 设置height–>

<hr />

<div style=”position:relative;height:60px;border:1px solid orange;text-align:center;”>

<a href=”http://www.111cn.net”>http://www.111cn.net/</a>

<div style=”position:absolute;bottom:0;left:0;background:#ccc;”></div>

</div>

trbl属性

(top、right、bottom、left)只有当设定了position属性才有效。

当设定position:absolute

如果父级(无限)没有设定position属性,那么当前的absolute则结合trbl属性以浏览器左上角为原始点进行定位

如果父级(无限)设定position属性,那么当前的absolute则结合trbl属性以父级(最近)的左上角为原始点进行定位。

当设定position: relative

则参照父级(最近)的内容区的左上角为原始点结合trbl属性进行定位(或者说相对于被定位元素在父级内容区中的上一个元素进行偏移),无父级则以body的左上角为原始点。相对定位是不能层叠的。在使用相对定位时,无论元素是否进行移动,元素依然占据原来的空间。因此,移动元素会导致它覆盖其他框。

一般来讲,网页居中的话用absolute就容易出错,因为网页一直是随着分辨率的大小自动适应的,而absolute则会以浏览器的左上角为原始点,不会应为分辨率的变化而变化位置。有时还需要依靠z-index来设定容器的上下关系,数值越大越在最上面,数值范围是自然数。当然有一点要注意,父子关系是无法用z-index来设定上下关系的,一定是子级在上父级在下。

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...