css設定元素位置不變的方法:先建立一個HTML範例檔;然後定義一個「#ads」的id樣式,並設定高度寬度;最後透過「position:fixed」以及right、bottom將元素定位在指定位置即可。
本教學操作環境:windows7系統、css3版、thinkpad t480電腦。
推薦:《css影片教學》
我們經常碰到的需求是希望頁面某個元素固定在瀏覽器的一個位置,無論如何滾動滾動條,位置不變,就例如經常看到的彈出廣告。方法一般是使用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將元素定位在視窗右下角。
使用position:fixed可以直接以瀏覽器視窗作為參考進行定位,它是浮動在頁面中,元素位置不會隨瀏覽器視窗的滾動條滾動而變化;除非你在螢幕中移動瀏覽器視窗的螢幕位置,或改變瀏覽器視窗的顯示大小,因此固定定位的元素會始終位於瀏覽器視窗內視圖的某個位置,不會受文件流影響。
但在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; }
以上是css如何設定元素位置不變的詳細內容。更多資訊請關注PHP中文網其他相關文章!