共计 1423 个字符,预计需要花费 4 分钟才能阅读完成。
我们经常碰到的需求是希望页面某个元素固定在浏览器的一个位置,无论如何滚动滚动条,位置不变,就例如经常看到的弹出广告。方法一般是使用 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,如下:
ps: 原本使用的是 ””, 但是 txt 这个是不存在的,http 请求报 404 错误,导致影响加载速度,参考了网上的一些写法,使用 about:blank 可以达到相同目的。
原理据说是 ie6 不支持 fixed 而其样式背景却支持 fixed,通过背景来此消彼长消除抖动,望大牛指教。
完整的代码:
body{
background-image:; /* 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;
}
然而有些时候这些固定的区域会显示在下拉内容的下面怎么才能让他显示在最上层呢,对了设置 z -index 就是设置 z -index
z-index:999999