IE6 position:fixed 問題解決方法

tomivy 14年前發布 | 2K 次閱讀 SmartSVN 診斷工具 NOSQL

今天herb同學在推ter上問到,如何利用CSS使搜索條固定顯示于窗口的某個位置。好像之前也碰過這個問題,不過,當時并沒有解決,用JS有現成的方法,不過,這次要求的就是不用JS。然后,開始寫代碼,測試,最終,IE6下依然有問題。position:fixed;沒有正常顯示。

ie6 position:fixed bug

正確的代碼:預覽/Demo | ie6_position_fixed_bug.txt(源代碼)

在別的文章中看到,可以用position:absolute;來解決IE6的問題,不過,添加position:absolute;之后,依然沒有成功。當然,最終,還是用position:absolute;來解決。只是,不一定能成功。因為,有一句非常重要的話需要理解。

fixed元素的絕對位置是相對于HTML元素來說,滾動條是body元素的。(via,剛才竟然沒找到來源,囧。)

只有記住了這句話,才知為什么position:absolute;很多地方都給出了結果,但當時并未能解決。因為html被我設置position:relative。是上面這一句啟發了我,最終才能夠解決這個問題。我們拉動滾動條的時候,內容都會隨著窗口滾動;這時滾動的是body。如果讓絕對定位的父級元素定為body,剛我們需要固定的某個模塊將會固定在網頁的某個位置,而不是固定在窗口的某個位置(貌似在firefox中,html與body之間的介限并不明確?)。

我們需要做的是,讓body保持其原有高度,讓html只有一個窗口那么高。代碼我們可以這樣寫:

html{overflow:hidden;} // 重要!
body{height:100%;overflow:auto;}

這時,html將只有一個窗口那么高,超過的,直接hide。而body會隨高度自動變化。這時,我們可以利用絕對定位來定位我們想要固定在窗口某個位置的模塊。假設我們要固定的內容在右上角,代碼可以這樣寫:

html{overflow:hidden;}
body{height:100%;overflow:auto;}
#rightform form{position:absolute;right:30px;top50px;}

這樣,窗口就固定在右上角了。而其他瀏覽器,我們可以用position:fixed;來解決固定的問題。其他瀏覽器完整的代碼如下:

#rightform {text-align:center;padding:50px;font:14px/22px Georgia, "Times New Roman", Times, serif;height:1200px;background:#ffc;}
#rightform h1 {font-family:arial;background:#e8edef;height:300px;line-height:300px;margin-bottom:200px;}
#rightform p {line-height:1.5em;background:#ffdfff;padding:90px 0;}
#rightform form {background-color:#ddd;padding:10px 20px;border:1px solid #aaa;position:fixed;right:30px;top:120px;}

完整代碼請看上面鏈接提供的txt文件。問題的原理就是這么簡單。不知道,你能理解不?

 

原文出處:

http://sofish.de/991

 本文由用戶 tomivy 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!