document.body.scrollTop与document.documentElement.scrollTop兼容
2015-04-01 22:15
169 查看
document.body.scrollTop与document.documentElement.scrollTop兼容
这两天在写一个JS的网页右键菜单,在实现菜单定位的时候发现了这个问题: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造成影响。一点小技巧,但很实用。
相关文章推荐
- js获取浏览器基本信息:document.body.clientWidth/clientHeight/scrollWidth/scrollTop。
- XHTML document.body.scrollTop无效解决方法
- IE/FF/Chrome下document.documentElement和document.body的 scrollHeight/scrollTop/clientHeight 以及判断滚动条是否已拉到页面最底部
- Document.body.scrollTop的值总为零的快速解决办法
- 火狐、谷歌、IE关于document.body.scrollTop和document.documentElement.scrollTop 以及值为0的问题
- document.body.scrollTop的值总为零的解决办法
- xhtml1中不支持document.body.scrollTop的解决方式
- 火狐、谷歌、IE关于document.body.scrollTop和document.documentElement.scrollTop 以及值为0的问题
- document.body.scrollTop与document.documentElement.scrollTop兼容
- IE/FF/Chrome下document.documentElement和document.body的 scrollHeight/scrollTop/clientHeight 以及判断滚动条是否已拉
- document.body.scrollTop为0的处理办法
- document.body.scrollTop 值总为 0 的解决方法
- document.body.scrollTop 值总为 0 的解决方法
- document.body.scrollTop用法
- document.body.scrollTop总是零的原因
- (javascript)再说document.body.scrollTop的使用问题
- document.body.scrollTop用法
- 关于js中 document.body.scrollTop 不能返回正确值的原因
- document.body.scrollTop总是零的原因(zz)
- 解决scrollTop兼容问题 document.documentElement.scrollTop || document.body.scrollTop