学习笔记 如何解决IE6 position:fixed固定定位问题

开发 前端
本文和大家分享一下解决IE6 position:fixed固定定位问题的方法,就像你所遇到的问题一样,IE6有太多的bug让制作网页的人头疼,相信你对本文介绍一定会感兴趣。

你知道解决IE6 position:fixed固定定位问题方法吗,这里和大家简单分享一下,希望本文的介绍能让你有所收获。

解决IE6 position:fixed固定定位问题

就像你所遇到的问题一样,IE6有太多的bug让制作网页的人头疼。这篇文章介绍的是介绍我的如何解决IE6不支持position:fixed;属性的办法。

◆关于position:fixed;属性生成绝对定位的元素,相对于浏览器窗口进行定位。
元素的位置通过“left”,“top”,“right”以及“bottom”属性进行规定。

position:fixed;可以让网页上的某个元素固定在一个绝对的位置,即使拉动滚动条位置也不发生变化。在LOO2K博客右下角的那个置顶的小按钮就是用了这个CSS属性实现的

一般的position:fixed;实现方法以我的博客为例,在右下角<divid="top">...</div>这个HTML元素使用的CSS代码如下:

  1. #top{  
  2. position:fixed;  
  3. bottom:0;  
  4. right:20px;  
  5. }  
  6.  

实现让<divid="top">...</div>元素固定在浏览器的底部和距离右边的20个像素。

◆在IE6中实现position:fixed;的办法刚刚提过,在IE6中是不能直接使用position:fixed;。你需要一些CSSHack来解决它。当然,IE6的问题也不仅仅position:fixed;

相同的还是让<divid="top">...</div>元素固定在浏览器的底部和距离右边的20个像素,这次的代码是:

  1. #top{  
  2. position:fixed;  
  3. _position:absolute;  
  4. bottom:0;  
  5. right:20px;  
  6. _bottom:auto;  
  7. _top:expression(eval(document.documentElement.scrollTop+document.  
  8.  
  9. documentElement.clientHeight-this.offsetHeight-(parseInt(this.  
  10.  
  11. currentStyle.marginTop,10)||0)-(parseInt(this.currentStyle.marginBottom,10)||0)));  
  12. }  
  13.  

right跟left属性可以用绝对定位的办法解决,而top跟bottom就需要用上面的表达式来实现。其中在_position:absolute;中的_符号只有IE6才能识别,目的是为了区分其他浏览器。

上面的只是一个例子,下面的才是最重要的代码片段:

◆使元素固定在浏览器的顶部:

  1. #top{  
  2. _position:absolute;  
  3. _bottom:auto;  
  4. _top:expression(eval(document.documentElement.scrollTop));  
  5. }  
  6.  

◆使元素固定在浏览器的底部:

  1. #top{  
  2. _position:absolute;  
  3. _bottom:auto;  
  4. _top:expression(eval(document.documentElement.scrollTop+document.  
  5.  
  6. documentElement.clientHeight-this.offsetHeight-(parseInt(this.currentStyle.marginTop,10)  
  7.  
  8. ||0)-(parseInt(this.currentStyle.marginBottom,10)||0)));  
  9. }  
  10.  

◆这两段代码只能实现在最底部跟最顶部,你可以使用_margin-top:10px;或者_margin-bottom:10px;修改其中的数值控制元素的位置。

position:fixed;闪动问题现在,问题还没有完全解决。在用了上面的办法后,你会发现:被固定定位的元素在滚动滚动条的时候会闪动。解决闪动问题的办法是在CSS文件中加入:

  1. *html{  
  2. background-image:url(about:blank);  
  3. background-attachment:fixed;  
  4. }  
  5.  

其中*是给IE6识别的。

到此,IE6的position:fixed;问题已经被解决了。现在LOO2K这个博客上的固定定位就是使用的这个办法解决IE6固定定位问题的。

【编辑推荐】

  1. 深入探究margin在FF IE6 IE7中的兼容问题
  2. 探究IE8与IE7具体功能中窗口功能按钮的变化
  3. IE6 IE7 IE8三个版本的CSS兼容速查手册
  4. IE6下使用CSS定义DIV高度行之有效的办法
  5. 技术前沿 一段JS代码轻松解决IE6-IE8的兼容性问题

 

责任编辑:佚名 来源: loo2k.com
相关推荐

2010-09-15 14:22:05

IE6position

2010-09-15 14:14:29

IE6position

2010-09-15 14:56:18

CSSposition:fi

2010-08-19 10:40:36

position:fiIE6

2010-09-15 15:03:52

CSS positio

2010-08-19 09:37:35

IE6fixed

2010-08-25 11:23:31

IE6margin

2010-08-18 09:24:09

IE6兼容性

2010-10-08 16:31:08

AjaxIE6

2010-08-27 15:08:10

FirefoxIE6IE7

2010-08-19 09:29:26

hoverIE6

2010-08-19 14:19:12

IE6IE7IE8

2010-08-27 13:31:58

IE6IE7Firefox

2010-09-15 08:41:25

IE6IE7Firefox兼容

2009-08-14 09:20:40

抵制IE6

2010-09-10 13:07:51

CSS DIV绝对定位CSS DIV固定定位

2010-08-20 13:15:54

IE6IE7IE8

2010-08-19 16:06:15

2010-10-08 13:55:22

JavaScriptIE6

2010-08-19 15:04:26

IE6DIV
点赞
收藏

51CTO技术栈公众号