国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > CSS > 正文

CSS{position:fixed}讓HTML固定在瀏覽器的某個位置

2024-07-11 09:02:16
字體:
來源:轉載
供稿:網友

武林網(www.survivalescaperooms.com)文章簡介:跨瀏覽器的CSS固定定位{position:fixed}.

不知道您是否留意了,瀏覽本站時,瀏覽器右下角有一個標著top的黑色直角三角形,可以點擊它返回到正在瀏覽的網頁頁眉。當滾動網頁時,它的位置一直沒有任何改變,您感覺它怎么樣?這就是通過CSS的定位屬性{position:fixed}來實現的,通過它可以讓HTML元素脫離文檔流固定在瀏覽器的某個位置。

實現代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"""><html xmlns=""><head>......<style type="text/css">#fixed{position:fixed;top:5em;right:0;......} 針對IE7、Opera、Firefox一行搞定</style>IE6中利用容器對溢出內容的處理方式來實現的<!--[if IE 6]><style type="text/css">html{overflow:hidden;}body{height:100%;overflow:auto;}#fixed{position:absolute;right:17px;}fixed元素的絕對位置是相對于HTML元素來說,滾動條是body元素的,這是設置right:17px的原因</style><![endif]--><!--[if lt IE 6]><style type="text/css">#fixed{position:absolute;top:expression(eval(document.body.scrollTop + 50));}</style><![endif]--></head><body><div id="wrapper">......</div><div id="fixed"><h2>{position:fixed}</h2></div></body></html>

(單個IE,純粹通過條件注釋區分IE瀏覽器)

(多個IE,通過條件注釋+CSS hack區分IE瀏覽器,明顯的比純粹條件注釋復雜且不易讀,放上來主要是便于同個PC擁有多個IE瀏覽器朋友[一般應該做是web開發的]可以直接看到效果,下同。)

或許有人像我一樣,在!DOCTYPE 聲明是XHTML1.0 Strict或者是XHTML1.1時,喜歡在聲明前面加上XML Prolog(如:<?xml version="1.0" encoding="utf-8"?>),但此時IE7以下都處于Quirks(兼容)模式,所以上述針對IE6的Hack失效,這個時候你可以對IE6也通過expression來實現。

當IE6處于quriks模式時,IE6和IE5.5對CSS解析方式幾乎雷同,所以當看到《position:fixed for Internet Explorer》時,我找到了在Quirks模式下IE6/IE5.5/IE5統一的CSS解決方案:

<?xml version="1.0" encoding="utf-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"""><html xmlns="" xml:lang="zh" lang="zh"><head>......<!--[if lt IE 7]><style type="text/css">body{overflow:hidden;}#wrapper{height:100%;overflow:auto;}#fixed{position:absolute;right:17px;}</style><![endif]--></head><body><div id="wrapper">......</div><div id="fixed"><h2>{position:fixed}</h2></div></body></html>

(單個IE,純粹通過條件注釋區分IE瀏覽器)

(多個IE,通過條件注釋+CSS hack區分IE瀏覽器)

對比兩個純粹的CSS hack發現,兩個原理似乎相同,在于html元素和body元素的應用和對CSS的{position:fixed}的支持程度上,但是這實際上是一種Hack,基本上不具備通用性,知道這個方法就可以了。需要提醒的是IE6 standards-compliant模式下HTML元素不管給它設置什么樣的高度和寬度,它的大小都始終充滿整個瀏覽器的可視區域,而IE5 以及 Quirks 模式下html元素和body元素所有寬高設置都會被忽略而保持充滿瀏覽器的可視區域,更多內容請看《IE 中的 html 元素》

或許有人會想,現在可以引入了XML Prolog又能用純CSS方法解決了IE7以下的問題,這下爽了,但是加上XML Prolog后突然發現IE6處于Quirks模式,以前在standards-compliant模式下的設計又變形了,呵呵,這就是咱們搞IE的下場。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 垣曲县| 始兴县| 道孚县| 广水市| 涟源市| 巴东县| 台安县| 紫金县| 电白县| 巧家县| 前郭尔| 若尔盖县| 邢台县| 古田县| 蒙阴县| 尚义县| 同江市| 鸡西市| 都昌县| 棋牌| 巴塘县| 利辛县| 靖远县| 鹤峰县| 墨脱县| 太康县| 富蕴县| 凯里市| 大余县| 舞钢市| 新野县| 武鸣县| 城固县| 陕西省| 青州市| 辛集市| 临清市| 宣恩县| 眉山市| 万载县| 新丰县|