我正在构建一个非常基本的 web 应用程序来显示轮渡时刻表。
我正在使用 phonegap 将其移植到 Android 上的“本机”应用程序,但滚动时遇到了一些麻烦。
它可以在设备上的 Chrome 以及 android 浏览器上完美运行。我已经在几种设备上进行了测试,它们在浏览器中都运行良好。一旦我将项目放入Phonegap,滚动就会变得非常“断断续续”并且会跳动并粘住。我添加了一个视频链接来向您展示行为:
我将简要解释一下它的工作原理:
当我们在视图中切换内容时,我们使用 translate3d CSS 方法进行转换,以避免使用页面转换。因此,我们不会滚动实际页面,而是滚动单个内容 div,以避免在内容视图之间切换时出现奇怪的滚动错误。基本上,我们在一个页面上有三个“内容视图”,当我们想要切换视图时它们会切换出来。
这是该应用程序的链接:
我尝试过的事情
我们正在使用“overscroll:scroll;” 这些内容 div 之一,我知道它与 Android 2.3 之前的版本有些不兼容,但现在应该很好。
我们尝试了一些大型库,例如 iScroll 和 Scrollable,但类似的东西都无济于事。
我尝试阻止 touchmove 的默认操作。
我们使用 Zepto 的触摸模块编写了正确的触摸事件。
我已经在从 Nexus one (4.0.4) 到 Nexus 7 (4.3) 的设备上进行了测试,所有这些设备的情况都是一样的。
任何帮助将不胜感激
我已经为此苦苦挣扎了一段时间,我似乎无法在互联网上找到任何与这个“断断续续”的滚动错误有关的内容。
编辑:这是从安装到滚动错误发生时的 logcat:http: //pastebin.com/Aa7mDeAX