你知道解决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代码如下:
- #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固定定位问题的。
【编辑推荐】
- 深入探究margin在FF IE6 IE7中的兼容问题
- 探究IE8与IE7具体功能中窗口功能按钮的变化
- IE6 IE7 IE8三个版本的CSS兼容速查手册
- IE6下使用CSS定义DIV高度行之有效的办法
- 技术前沿 一段JS代码轻松解决IE6-IE8的兼容性问题