document.body.scrollTop与document.documentElement.scrollTop兼容
2016-06-08 14:17
316 查看
这两天在写一个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造成影响。一点小技巧,但很实用。
还有一个方法,我们可以写成这样:同样达到兼容目的!
var sTop = document.documentElement.scrollTop || document.body.scrollTop;
By YuqiDai@G
看前辈们的文章,纷纷表示如果有文档声明(即网页第一句的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造成影响。一点小技巧,但很实用。
还有一个方法,我们可以写成这样:同样达到兼容目的!
var sTop = document.documentElement.scrollTop || document.body.scrollTop;
By YuqiDai@G
相关文章推荐
- 安装桌面
- [Ubuntu]如何安装Tomcat
- pull解析和Tomcat
- apache 开机自启动脚本设置
- hadoop 编译native包
- SUSE Linux 防火墙设置
- jiffies & HZ
- 用Hadoop1.0.3实现KMeans算法
- hadoop下实现kmeans算法——一个mapreduce的实现方法
- hadoop下的Kmeans算法实现
- docker on mac:误删default vm的处理方法
- 使用weave实现跨主机docker容器互联
- 学习网站 - URLs
- KMeans聚类算法Hadoop实现
- Linux进程概论
- jndi 数据源配置密码加密
- flashdevelop生成swc库
- Nginx 进程间的关系
- [转]大型网站架构系列:消息队列(二)
- lamp+nginx代理+discuz+wordpress+phpmyadmin