css固定元素位置(fixed)

我们经常碰到的需求是希望页面某个元素固定在浏览器的一个位置,无论如何滚动滚动条,位置不变,就例如经常看到的弹出广告。方法一般是使用 js 控制,或者使用 css。这里我写的是 css 的控制方法。

在 IE7 以上版本及 firefox、opera、safari 里,都支持 css 属性 "position:fixed",它的作用就是将元素相对于窗口固定位置。代码如下

#ads{
    position
:fixed;
    right
:0;
    bottom
:0;
    border
:1px solid red;
    width
:300px;
    height
:250px;
}

我们定义一个 #ads 的 id 样式,并给他设了高度宽度,通过 position:fixed 以及 right、bottom 将元素定位在窗口右下角。

但是在 IE6 下,并不支持 position:fixed 属性,这个时候我们需要对 IE6 进行 hack 处理。解决的方案是使用 postion:absolute 属性,它的作用大家都很熟悉,相对于父元素进行绝对定位,然后我们可以通过 expression 来改变 #ads 的 top 值。

PS expression 的定义:IE5 及其以后版本支持在 CSS 中使用 expression,用来把 CSS 属性和 Javas cript 表达式关联起来,这里的 CSS 属性可以是元素固有的属性,也可以是自定义属性。就是说 CSS 属性后面可以是一段 Javas cript 表达式,CSS 属性的值等于 Javas cript 表达式计算的结果。 在表达式中可以直接引用元素自身的属性和方法,也可以使用其他浏览器对象。这个表达式就好像是在这个元素的一个成员函数中一样。

所以我们可以通过在 css 里计算 javascript 值来改变 top 值,代码如下:

#ads{
    _position
:absolute;
    _top
:expression(documentElement.scrollTop + documentElement.clientHeight-this.offsetHeight);
}

似乎一切都完美了,但是我们在 IE6 下运行的时候会发现,随着滚动条的移动,我们的这个 #ads 朋友他会抖动。解决方法也很简单,只要在 body 里加一点点的 css,如下:

body{
    background-image
:url(about:blank); /* for IE6 */ 
    background-attachment
:fixed; /*必须*/
}

好啦,完工!!!!!!!!!!!!!!!!!!!!!!!!

有木有!!!!!!!!!!!!!!!!!!!!!!!!

PS: 原本使用的是 "url(text.txt)", 但是 txt 这个是不存在的,http 请求报 404 错误,导致影响加载速度,参考了网上的一些写法,使用 about:blank 可以达到相同目的。

原理据说是 ie6 不支持 fixed 而其样式背景却支持 fixed,通过背景来此消彼长消除抖动,望大牛指教。

完整的代码:

body{
    background-image
:url(about:blank); /* for IE6 */ 
    background-attachment
:fixed; /*必须*/
}
#ads
{
    width
:300px;
    height
:250px;
    position
:fixed;
    right
:0;
    bottom
:0;
    _position
:absolute;
    _top
:expression(documentElement.scrollTop + documentElement.clientHeight-this.offsetHeight);
    border
:1px solid red;
}