您的位置:首页 > 其它

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

2012-11-13 11:45 369 查看
解决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代码如下:

#top{

position:fixed;

bottom:0;

right:20px;

}

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

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

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

#top{

position:fixed;

_position:absolute;

bottom:0;

right:20px;

_bottom:auto;

_top:expression(eval(document.documentElement.scrollTop+document.

documentElement.clientHeight-this.offsetHeight-(parseInt(this.

currentStyle.marginTop,10)||0)-(parseInt(this.currentStyle.marginBottom,10)||0)));

}

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

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

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

#top{

_position:absolute;

_bottom:auto;

_top:expression(eval(document.documentElement.scrollTop));

}

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

#top{

_position:absolute;

_bottom:auto;

_top:expression(eval(document.documentElement.scrollTop+document.

documentElement.clientHeight-this.offsetHeight-(parseInt(this.currentStyle.marginTop,10)

||0)-(parseInt(this.currentStyle.marginBottom,10)||0)));

}

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

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

*html{

background-image:url(about:blank);

background-attachment:fixed;

}

其中*是给IE6识别的。

到此,IE6的position:fixed;问题已经被解决了。现在LOO2K这个博客上的固定定位就是使用的这个办法解决IE6固定定位问题的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: