在主题制作或者修改中一些元素要设置 为随页面滚动的效果,通常的做法是加上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">
【让IE6浏览器支持fixed的方法】这一句那么可以用document.body.scrollTop,否则只能用 document.documentElement.scrollTop 。
原因:在标准w3c下,document.body.scrollTop恒为0,需要用 document.documentElement.scrollTop来代替;document.documentElement.scrollTop 中documentElement 对应的是 html 标签;document.body.scrollTop 中 body 对应的是 body 标签 。
推荐阅读
- 踏雪无痕 巧用浏览器自带隐私保护功能
- 让w900代替鼠标控制你的电脑
- 搜狗高速浏览器怎么开启安全防护
- IObit Malware Fighter开启浏览器保护功能的方法
- Windows10打开浏览器下载位置提示方法介绍
- 搜狗浏览器怎么退出用户体验改善计划
- 搜狗浏览器怎么关闭追剧提醒
- 搜狗高速浏览器显示不是电脑中的默认浏览器怎么办
- 搜狗高速浏览器怎么关闭自动刷新
- edge浏览器怎么恢复出厂设置