如何精确地获得页面的最大滚动位置

How to get the maximum scroll position of a page precisely?

本文关键字:滚动 位置 何精确      更新时间:2024-06-08

如果我使用公式

document_height - window_height = max_scroll_position

它的求值结果为1或0,尽管我认为它应该始终求值为0。例如,在firefox打开控制台,滚动到页面底部http://stackoverflow.com并在控制台上执行以下操作:

($(document).height() - $(window).height()) - $(document).scrollTop()

我得到1作为答案(记得将滚动位置保持在最底部)然而,在jquery.com上,执行上述操作会得到0

我错过了什么?

经过一些测试,额外的1个像素肯定是舍入误差。所有这三个变量(文档高度、窗口高度和滚动顶部)都保持较高的内部精度或未缩放浏览器窗口的比例,然后根据需要进行缩放和取整,以满足JavaScript属性的要求。在某些边缘情况下,随着缩放比的增加,这些值会以一种产生不一致结果的方式进行舍入,这种情况变得更可能发生。

除非您根据其他变量的值多次快速调整其中一个或多个变量,否则这种舍入误差不太可能导致用户看到任何问题。如果你必须经常调整它们,那么你可能应该缓存调整后的数字,并使用缓存的版本而不是浏览器报告的数字进行进一步计算。

[注意:我最终能够使用OP中的公式获得-1的舍入误差,在Firefox中缩放250%。]