让IE6支持fixed的简单方法

axiu 撰写于 2010/06/29 | 92 条评论

最近感觉很忙,又有点闲时间来更新博客。折腾着折腾着发现一个小问题:在主题制作或者修改中一些元素要设置为随页面滚动的效果,通常的做法是加上fixed属性,或者干脆用js实现这个功能。

不过对于懒得去后台更新js文件的同学来说,这不是个好办法,或者对于还未引入js的同学,这更不是好办法。但是不用的话在IE6下会无效,这个经典到目前访问量的半数以上的浏览器版本是直接无视fixed的(当然还有其他若干问题,所以希望更新或扔掉该浏览器)。

关于这个问题的解决办法,我之前的做法一直是用_position:absolute来暂时修订,当然这么做产生的效果和想象中的差距很大。最近发现一个方法来修正IE6的fixed效果,如下:

_top:expression(documentElement.scrollTop + 数值 + "px")

也是一个简单的hack,对于不想引入JS又迫切希望使用fixed属性的人来说,确实是个好办法。

More:

Q:有时候好像使用document.body.scrollTop来获取滚动条滚动的长度,结果滚动后得到的也是0,为什么改用document.documentElement.scrollTop就可以了?

A:可以查看一下源代码,如果没有

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

这一句那么可以用document.body.scrollTop,否则只能用document.documentElement.scrollTop

原因:在标准w3c下,document.body.scrollTop恒为0,需要用document.documentElement.scrollTop来代替;document.documentElement.scrollTop中documentElement 对应的是 html 标签;document.body.scrollTop 中 body 对应的是 body 标签。

评论:92

  1. 集趣 集趣 10/06/30

    暂时还没有用过这个样式~

  2. zwwooooo zwwooooo 10/06/30

    ie6就让它去吧

  3. 卢松松 卢松松 10/06/30

    嘿嘿 这招很管用

  4. 博百优 博百优 10/06/30

    我还是乖乖的用我的IE8

  5. 技术文啊..看到我一头雾水了..嘿嘿

  6. Kada Kada 10/06/30

    明天断网,赶来一踩。

  7. Junan Junan 10/06/30

    我的主题在IE6下也是错位的。不会改、 :cry:

  8. 添一块砖~~~~、

    :oops:

  9. 小羿 小羿 10/07/01

    无视ie6~~~

    • axiu axiu 10/07/01

      @小羿 我也想无视,不过后来觉得稍微照顾一下它吧~岁数那么大了

  10. YoungCheon YoungCheon 10/07/01

    这次的皮肤有点味道,CSS3用的也不错啊,年轻真好!~

    • axiu axiu 10/07/01

      @YoungCheon :twisted: 太棒啦,终于得到正面评价了,很高兴。你也很年轻呢~

  11. 苏扬 苏扬 10/07/01

    离开IE6已经很久了,看你的banner,居然是一个阿根廷球迷 哈哈!

    • axiu axiu 10/07/01

      @苏扬 终于有人发现啦,我确实很喜欢阿根廷啊!~~

  12. 指舞六弦 指舞六弦 10/07/02

    阿修,貌似那天我说的滚动条就按照你这个方法解决袄?我在这里看见滚动条啦

  13. 拆墙部队 拆墙部队 10/07/02

    有没有复杂的方法让自行车支持 V12 涡轮增压发动机啊?

  14. 混生 混生 10/07/02

    现在IE6的人应该不多了。

  15. 指舞六弦 指舞六弦 10/07/03

    啊悲剧的巴西,回家了哦

发表评论

电子邮件地址不会被公开。 必填项已用 * 标注

*

:razz:

您可以使用这些 HTML 标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong> <pre lang="" line="" escaped="" highlight="">