js获取滚动条位置

来源:互联网 发布:sql范围查询语句 编辑:程序博客网 时间:2024/06/06 00:45
document.body.scrollTop与document.documentElement.scrollTop兼容


问题:chrome居然不认识document.documentElement.scrollTop!


看前辈们的文章,表示如果有文档声明(即网页第一句的docType)的情况下,标准浏览器是只认识documentElement.scrollTop的,但chrome虽然我感觉比firefox还标准,但却不认识这个,在有文档声明时,chrome也只认识document.body.scrollTop.


由于在不同情况下,document.body.scrollTop与document.documentElement.scrollTop都有可能取不到值,那到底网页的scrollTop值怎么得到呢?难道又要用JavaScript进行判断?


其实不必。因为document.body.scrollTop与document.documentElement.scrollTop两者有个特点,就是同时只会有一个值生效。比如document.body.scrollTop能取到值的时候,document.documentElement.scrollTop就会始终为0;反之亦然。所以,如果要得到网页的真正的scrollTop值,可以这样:


var sTop=document.body.scrollTop+document.documentElement.scrollTop;


这两个值总会有一个恒为0,所以不用担心会对真正的scrollTop造成影响。一点小技巧,但很实用。

0 0
原创粉丝点击