日期:2013-12-01 浏览次数:21222 次
实现代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <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" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" 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的下场。