您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關怎么在css中固定住元素不變,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
#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 值。
expression的定義:IE5及其以后版本支持在CSS中使用expression,用來把CSS屬性和Javascript 表達式關聯起來,這里的CSS屬性可以是元素固有的屬性,也可以是自定義屬性。就是說CSS屬性后面可以是一段Javascript表達式,CSS屬性 的值等于Javascript表達式計算的結果。 在表達式中可以直接引用元素自身的屬性和方法,也可以使用其他瀏覽器對象。這個表達式就好像是在這個元素的一個成員函數中一樣。
所以我們可以通過在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; /*必須*/ }
完整的代碼:
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中固定住元素不變就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。