在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
}
需要注意的是IE6可不支持fixed,一般用_position:absolute加js来代替fixed的实现
/* 除IE6浏览器的通用方法 */
.ie6fixedTL {position:fixed
left:0
top:0
}
.ie6fixedBR {
position:fixed
right:0
bottom:0
}
/* IE6浏览器的特有方法 */
* html .ie6fixedTL {position:absolute
left:expression(eval(document.documentElement.scrollLeft))
top:expression(eval(document.documentElement.scrollTop))
}
* html .ie6fixedBR {
position:absolute
left:expression(eval(document.documentElement.scrollLeft+document.documentElement.clientWidth-this.offsetWidth)-(parseInt(this.currentStyle.marginLeft,10)||0)-(parseInt(this.currentStyle.marginRight,10)||0))
top:expression(eval(document.documentElement.scrollTop+document.documentElement.clientHeight-this.offsetHeight-(parseInt(this.currentStyle.marginTop,10)||0)-(parseInt(this.currentStyle.marginBottom,10)||0)))
}
上面代码可以直接使用了,如果要设置元素悬浮边距,要分别为设置两次,比如我要让某个元素距顶部10个像素,距左部也是10个像素,那就要这样子写:
?
/* 除IE6浏览器的通用方法 */
.ie6fixedTL {position:fixed
left:10px
top:10px
}
/* IE6浏览器的特有方法 */
* html .ie6fixedTL {position:absolute
left:expression(eval(document.documentElement.scrollLeft+10))
top:expression(eval(document.documentElement.scrollTop+10))
}
你是想把div紧贴中间区域吧,然后你再你的22寸显示器上设置了一个固定的right,而fixed是距离浏览器边缘的,你要是把你的22寸的浏览器改下窗口大小,一样会出问题,你需要做的是用js计算出距离浏览器边缘的距离,然后用js设置left或者right值,当浏览器触发resize方法的时候重新计算