固定窗口方法 IE6 position:fixed bug
然后 , 開始寫代碼,測試,最終,IE6下依然有問題 。position:fixed;沒有正常顯示 。

正確的代碼:預覽/Demo | ie6_position_fixed_bug.txt(源代碼)
!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"html xmlns="http://www.w3.org/1999/xhtml"headmeta http-equiv="Content-Type" content="text/html; charset=utf-8" /titleIE6 position:fixed bug/titlestyle* { padding:0; margin:0;}#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;}/style!--[if IE 6]style type="text/css" html{overflow:hidden;} body{height:100%;overflow:auto;} #rightform form{position:absolute;}/style![endif]--/headbodydiv id="rightform"h1a href="" title="IE6 position:fixed bug" rel="bookmark"IE6 position:fixed bug/a/h2pposition:fixed; vs position:absolute;support by a title="經驗啦網"經驗啦網/a from jb51.net/pform id="g_search" method="get" action="#"input id="g_s" name="g_s" type="text" value=""/input id="g_submit" name="g_submit" type="button" value="https://www.questions.com.cn/dnjc/search" //form/div/body/html
ffcod = delpost.runcode21 .value; ffcod = ffcod.replace(/
/g,’’); delpost.runcode21 .value = https://www.questions.com.cn/dnjc/ffcod; 提示:您可以先修改部分代碼再運行
在別的文章中看到,可以用position:absolute;來解決IE6的問題,不過,添加position:absolute;之后,依然沒有成功 。當然,最終,還是用position:absolute;來解決 。只是 , 不一定能成功 。因為,有一句非常重要的話需要理解 。
【固定窗口方法 IE6 position:fixed bug】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文件 。問題的原理就是這么簡單 。不知道,你能理解不?
