滚动事件
每当元素滚动时,会触发scroll
事件。该事件用处极多,比如知道用户当前查看的元素(禁用用户视线以外的动画,或向邪恶的指挥部发送监视报告),或展示一些滚动的迹象(通过高亮表格的部分内容,或显示页码)。
以下示例在文档上方绘制一个进度条,并在您向下滚动时更新它来填充:
<style>
#progress {
border-bottom: 2px solid blue;
width: 0;
position: fixed;
top: 0; left: 0;
}
</style>
<div id="progress"></div>
<script>
// Create some content
document.body.appendChild(document.createTextNode(
"supercalifragilisticexpialidocious ".repeat(1000)));
let bar = document.querySelector("#progress");
window.addEventListener("scroll", () => {
let max = document.body.scrollHeight - innerHeight;
bar.style.width = `${(pageYOffset / max) * 100}%`;
});
</script>
将元素的position
属性指定为fixed
时,其行为和absolute
很像,但可以防止在文档滚动时期跟着文档一起滚动。其效果是让我们的进度条呆在最顶上。 改变其宽度来指示当前进度。 在设置宽度时,我们使用%
而不是px
作为单位,使元素的大小相对于页面宽度。
innerHeight
全局绑定是窗口高度,我们必须要减去滚动条的高度。你点击文档底部的时候是无法继续滚动的。对于窗口高度来说,也存在innerWidth
。使用pageYOffset
(当前滚动位置)除以最大滚动位置,并乘以 100,就可以得到进度条长度。
调用滚动事件的preventDefault
无法阻止滚动。实际上,事件处理器是在进行滚动之后才触发的。