css固定元素位置(fixed)
我们经常碰到的需求是希望页面某个元素固定在浏览器的一个位置,无论如何滚动滚动条,位置不变,就例如经常看到的弹出广告。方法一般是使用 js 控制,或者使用 css。这里我写的是 css 的控制方法。
在 IE7 以上版本及 firefox、opera、safari 里,都支持 css 属性 "position:fixed",它的作用就是将元素相对于窗口固定位置。代码如下
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 值,代码如下:
_position:absolute;
_top:expression(documentElement.scrollTop + documentElement.clientHeight-this.offsetHeight);
}
似乎一切都完美了,但是我们在 IE6 下运行的时候会发现,随着滚动条的移动,我们的这个 #ads 朋友他会抖动。解决方法也很简单,只要在 body 里加一点点的 css,如下:
background-image:url(about:blank); /* for IE6 */
background-attachment:fixed; /*必须*/
}
好啦,完工!!!!!!!!!!!!!!!!!!!!!!!!
有木有!!!!!!!!!!!!!!!!!!!!!!!!
PS: 原本使用的是 "url(text.txt)", 但是 txt 这个是不存在的,http 请求报 404 错误,导致影响加载速度,参考了网上的一些写法,使用 about:blank 可以达到相同目的。
原理据说是 ie6 不支持 fixed 而其样式背景却支持 fixed,通过背景来此消彼长消除抖动,望大牛指教。
完整的代码:
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;
}