原文地址:www.zhangxinxu.com/wordpress/?…html
题目以下(纸质打印拍摄图):git
是至关简单的一道题目,入门级别的,虽然挺简单,但还有不少细节是不少人不知道的,所以仍是颇有价值的。github
本题主要考察窗体滚动,窗体高度获取,普通元素高度获取这几个知识点。浏览器
本次B站直播在上午月10:15分开始,持续约40分钟,有录播,戳这里浏览。安全
你们回答地址这里:github.com/zhangxinxu/…bash
有很多人答题时候使用了节流函数,以下:微信
初衷是好的,滚动是一个高频触发的操做,经过节流函数能够下降计算方法执行的频率。可是,实际上,咱们开发的大多数页面是如此的简单,根本用不到须要节流函数,反而增长了代码的复杂度,对于本题,能够不须要。
dom
浏览器窗体滚动事件绑在哪一个对象上呢?是window
对象,仍是document
对象,或者是document.documentElement
,document.body
?ide
咱们不妨测试下:wordpress
window.addEventListener('scroll', function () {
console.log('window滚动触发,window.pageYOffset是:' + this.pageYOffset);
});
document.addEventListener('scroll', function () {
console.log('document滚动触发,document.scrollTop是:' + this.scrollTop);
});
document.documentElement.addEventListener('scroll', function () {
console.log('document.documentElement滚动触发,document.documentElement.scrollTop是:' + this.scrollTop);
});
document.body.addEventListener('scroll', function () {
console.log('document.body滚动触发,document.body.scrollTop是:' + this.scrollTop);
});复制代码
您能够识别此二维码:
或者直接点击这个页面:scroll滚动容器测试demo
结果不管是PC,仍是移动端,测试结果以下:
也就是window
对象和document
对象绑定scroll事件能够触发,document.documentElement
和document.body
是不行的。
而后,直播的时候有人在群里反馈,本身的手机document
滚动没法触发,若是这是真的,那安全起见,默认的浏览器窗体滚动事件仍是绑定在window
对象上。
如何获取窗体的滚动高度呢?常见的有下面3种代码:
window.pageYOffset;
document.documentElement.scrollTop;
document.body.scrollTop;复制代码
都是有效的吗?
咱们不妨测试下,想办法识别此二维码:
或者直接访问这个页面:3种窗体滚动高度获取方法测试demo
结果在PC上是这样:
而在手机上则是:
能够看到桌面浏览器和移动端浏览器对于滚动高度获取是有差异的,桌面端浏览器不能使用document.body.scrollTop
获取浏览器窗体的滚动高度,而移动端不能使用document.documentElement.scrollTop
获取浏览器窗体的滚动高度。可是都支持window.pageYOffset
。
因此,理论上讲,浏览器窗体的滚动高度获取使用window.pageYOffset
便可,然而window.pageYOffset
有一个缺点,就是IE9及其以上浏览器才支持,在PC端,不少项目是须要兼容IE8浏览器的,所以,对于传统PC网站,获取浏览器窗体滚动高度比较好的表达方法是这样:
var winScrollTop = window.pageYOffset || document.documentElement.scrollTop;复制代码
这个可使用window.innerHeight
获取。然而,window.innerHeight
有兼容性问题,IE8浏览器及其如下浏览器是不支持的,怎么办?能够借助document.documentElement.clientHeight
获取。
因而:
pre>var winHeight = window.innerHeight || document.documentElement.clientHeight;
document.documentElement
是个很特殊的对象,他的不少行为表现跟普通元素是不同的。例如,普通div这类元素的clientHeight
是不包括边框大小的,可是,document.documentElement.clientHeight
直接无视这些,不管你<html>
元素是否设置了border
,都是页面可视区域的高度。更神奇的是document.documentElement.offsetHeight
竟然是包含浏览器滚动高度的完整高度,等同于document.documentElement.scrollHeight
,你们能够特殊记忆下。
普通元素的滚动直接添加scroll事件就行了,没有任何兼容性差别。
dom.addEventListener('scroll', function () {
console.log('元素滚动触发,滚动高度是:' + this.scrollTop);
});复制代码
高度获取则使用clientHeight
,由于滚动的内容是不包括border-box
的:
dom.addEventListener('scroll', function () {
if (this.scrollTop > this.clientHeight) {
console.log('滚动超过一屏了');
}
});复制代码
对于普通元素的滚动高度获取,还有不少其余的原生API,例如offsetHeight
,包含border
边框大小;scrollHeight
包括滚动高度;getBoundingClientRect().height也是高度获取,不会能够是小数,特殊场景挺有用的。
重要参考文档
本文提到的pageYoffset,innerHeight,clientHeight,offsetHeight,getBoundingClientRect等原生API都属于CSSOM视图模式(CSSOM View Module)相关内容,本文这里只是一部分,更多内容能够参见本站经典文章:“CSSOM视图模式(CSSOM View Module)相关整理”。
下次直播预告
下周三群里发布CSS小测第2期正常,可是因为周六上班,有恰逢春节,所以直播答疑推迟到年后。想加入个人粉丝群的能够加我微信好友 zhangxinxu-job,我拉大家进去,备注“入群”,而后附上大家的姓名,方便我备注。
(完)