css固定元素位置(fixed)

咱們常常碰到的需求是但願頁面某個元素固定在瀏覽器的一個位置,不管如何滾動滾動條,位置不變,就例如常常看到的彈出廣告。方法通常是使用js控制,或者使用css。這裏我寫的是css的控制方法。 javascript

在IE7以上版本及firefox、opera、safari裏,都支持css屬性"position:fixed",它的做用就是將元素相對於窗口固定位置。代碼以下 css

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

咱們定義一個#ads的id樣式,並給他設了高度寬度,經過position:fixed以及right、bottom將元素定位在窗口右下角。 java

可是在IE6下,並不支持position:fixed屬性,這個時候咱們須要對IE6進行hack處理。解決的方案是使用postion:absolute屬性,它的做用你們都很熟悉,相對於父元素進行絕對定位,而後咱們能夠經過expression來改變#ads的top值。 express

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; /*必須*/
}

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

有木有!!!!!!!!!!!!!!!!!!!!!!!! this

PS:本來使用的是"url(text.txt)",可是txt這個是不存在的,http請求報404錯誤,致使影響加載速度,參考了網上的一些寫法,使用about:blank能夠達到相同目的。 url

原理聽說是ie6不支持fixed 而其樣式背景卻支持fixed,經過背景來此消彼長消除抖動,望大牛指教。 spa

完整的代碼:

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;
}
相關文章
相關標籤/搜索