gpt4 book ai didi

jquery - 使用 -webkit-overflow-scrolling : touch; 获取准确的滚动位置

转载 作者:行者123 更新时间:2023-11-28 08:48:44 27 4
gpt4 key购买 nike

我正在尝试使用 this fix在 iOS 5 中支持网页上的原生感觉滚动。我想在页面滚动时更新元素的位置,但是 scrollTop 返回的位置似乎与实际位置略有偏差页面上的元素。

我创建了一个示例,它试图在页面滚动时将一段文本保留在同一位置。如果您在 iOS 设备上尝试,您会发现文本实际上在四处抖动,而不是停留在完全相同的位置。这是令人沮丧的,因为直接使用 touchmove 事件,这可以在没有任何抖动的情况下完成。但显然,使用内置的滚动算法更可取。

有人知道解决方法吗?

示例:live

<!DOCTYPE html>
<html>
<head>
<title>Scrolling test</title>
<meta charset="utf8" />
<meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no" />
<style type="text/css" media="screen">
* {
margin: 0px;
padding: 0px;
-webkit-backface-visibility: hidden;
}
#outer, #wrapper {
position: absolute;
height: 100%;
width: 100%;
overflow: auto;
-webkit-overflow-scrolling: touch;
}
</style>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript" charset="utf-8">
$.event.props.push("touches");
$(function() {
$("#wrapper").on("touchmove", function(e) {
$("#thing").css("-webkit-transform", "translateY(" + ($(this).scrollTop()) + "px)");
});
});
</script>
</head>
<body>
<div id="outer">
<div id="wrapper">
<div id="thing">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</div>
</div>
</div>
</body>
</html>

最佳答案

我已经提交了 2 个与此相关的 Safari/WebKit 错误 (rdar://10980574) 和 (rdar://10980592)。如果有任何实质性更新(我记得),我会回来更新这个答案。

关于jquery - 使用 -webkit-overflow-scrolling : touch; 获取准确的滚动位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9557456/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com