document.documentElement.scrollTop||document.body.scrollTop;

这两天在写一个JS的网页右键菜单,在实现菜单定位的时候发现了这个问题:chrome竟然不认识document.documentElement.scrollTop!javascript

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

因为在不一样状况下,document.body.scrollTop与document.documentElement.scrollTop都有可能取不到值,那到底网页的scrollTop值怎么获得呢?难道又要用javascript进行判断?chrome

其实没必要。由于document.body.scrollTop与document.documentElement.scrollTop二者有个特色,就是同时只会有一个值生效。好比document.body.scrollTop能取到值的时候,document.documentElement.scrollTop就会始终为0;反之亦然。因此,若是要获得网页的真正的scrollTop值,能够这样:浏览器

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

这两个值总会有一个恒为0,因此不用担忧会对真正的scrollTop形成影响。一点小技巧,但很实用。ip

本站公众号
   欢迎关注本站公众号,获取更多信息