IE6 position:fixed bug (固定窗口方法)
發(fā)布時(shí)間:2011-04-26 11:44:23 作者:佚名
我要評論
今天herb同學(xué)在twitter上問到,如何利用CSS使搜索條固定顯示于窗口的某個位置。好像之前也碰過這個問題,不過,當(dāng)時(shí)并沒有解決,用JS有現(xiàn)成的方法,不過,這次要求的就是不用JS。
然后,開始寫代碼,測試,最終,IE6下依然有問題。position:fixed;沒有正常顯示。

正確的代碼:預(yù)覽/Demo | ie6_position_fixed_bug.txt(源代碼)
提示:您可以先修改部分代碼再運(yùn)行
在別的文章中看到,可以用position:absolute;來解決IE6的問題,不過,添加position:absolute;之后,依然沒有成功。當(dāng)然,最終,還是用position:absolute;來解決。只是,不一定能成功。因?yàn)椋幸痪浞浅V匾脑捫枰斫狻?
我們需要做的是,讓body保持其原有高度,讓html只有一個窗口那么高。代碼我們可以這樣寫:
html{overflow:hidden;} // 重要!
body{height:100%;overflow:auto;}
這時(shí),html將只有一個窗口那么高,超過的,直接hide。而body會隨高度自動變化。這時(shí),我們可以利用絕對定位來定位我們想要固定在窗口某個位置的模塊。假設(shè)我們要固定的內(nèi)容在右上角,代碼可以這樣寫:
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文件。問題的原理就是這么簡單。不知道,你能理解不?

正確的代碼:預(yù)覽/Demo | ie6_position_fixed_bug.txt(源代碼)
提示:您可以先修改部分代碼再運(yùn)行
在別的文章中看到,可以用position:absolute;來解決IE6的問題,不過,添加position:absolute;之后,依然沒有成功。當(dāng)然,最終,還是用position:absolute;來解決。只是,不一定能成功。因?yàn)椋幸痪浞浅V匾脑捫枰斫狻?
fixed元素的絕對位置是相對于HTML元素來說,滾動條是body元素的。(via,剛才竟然沒找到來源,囧。)
只有記住了這句話,才知為什么position:absolute;很多地方都給出了結(jié)果,但當(dāng)時(shí)并未能解決。因?yàn)閔tml被我設(shè)置position:relative。是上面這一句啟發(fā)了我,最終才能夠解決這個問題。我們拉動滾動條的時(shí)候,內(nèi)容都會隨著窗口滾動;這時(shí)滾動的是body。如果讓絕對定位的父級元素定為body,剛我們需要固定的某個模塊將會固定在網(wǎng)頁的某個位置,而不是固定在窗口的某個位置(貌似在firefox中,html與body之間的介限并不明確?)。我們需要做的是,讓body保持其原有高度,讓html只有一個窗口那么高。代碼我們可以這樣寫:
復(fù)制代碼
代碼如下:html{overflow:hidden;} // 重要!
body{height:100%;overflow:auto;}
這時(shí),html將只有一個窗口那么高,超過的,直接hide。而body會隨高度自動變化。這時(shí),我們可以利用絕對定位來定位我們想要固定在窗口某個位置的模塊。假設(shè)我們要固定的內(nèi)容在右上角,代碼可以這樣寫:
復(fù)制代碼
代碼如下:html{overflow:hidden;}
body{height:100%;overflow:auto;}
#rightform form{position:absolute;right:30px;top50px;}
這樣,窗口就固定在右上角了。而其他瀏覽器,我們可以用position:fixed;來解決固定的問題。其他瀏覽器完整的代碼如下:
復(fù)制代碼
代碼如下:#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文件。問題的原理就是這么簡單。不知道,你能理解不?
相關(guān)文章
這篇文章主要介紹了淺談原生頁面兼容IE9問題的解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起2020-12-16新版chrome瀏覽器設(shè)置允許跨域的實(shí)現(xiàn)
這篇文章主要介紹了新版chrome瀏覽器設(shè)置允許跨域的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起2020-11-30css hack之\9和\0就可能對hack IE11\IE9\IE8無效
每次設(shè)計(jì)一張網(wǎng)頁或一個表單,都被各種瀏覽器的兼容問題傷透腦筋,尤其是IE家族。在做兼容性設(shè)計(jì)時(shí),我們往往會使用各種瀏覽器能識別的獨(dú)特語法進(jìn)行hack,從而達(dá)到各種瀏覽2020-03-20css區(qū)分ie8/ie9/ie10/ie11 chrome firefox的代碼
這篇文章主要介紹了css區(qū)分ie8/ie9/ie10/ie11 chrome firefox的代碼,需要的朋友可以參考下2020-03-20
這篇文章主要介紹了解決CSS瀏覽器兼容性問題的4種方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)2020-02-28
這篇文章主要介紹了常見的瀏覽器兼容性問題(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)2020-02-20
這篇文章主要介紹了border-radius IE8兼容處理的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)2020-02-12- 這篇文章主要介紹了淺談遇到的幾個瀏覽器兼容性問題,詳細(xì)的介紹了幾種我遇到的問題和解決方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-09-26
這篇文章主要介紹了base64圖片在各種瀏覽器的兼容性處理的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-14
對常見的css屬性進(jìn)行瀏覽器兼容性總結(jié)(推薦)
這篇文章主要介紹了對常見的css屬性進(jìn)行瀏覽器兼容性總結(jié)(推薦)的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-20






