技术解析

js 如何解决移动端 webview 滚动穿透的问题.
0
2021-08-10 03:37:05
idczone

在开发一个 app 的部分 webview 功能,把页面滑动到页面的最顶部或最底部时候,页面因为惯性作用,还会往下或往上滚动一段距离后出现空白的背景再回弹.如何禁止这个滚动回弹的效果.


overscroll-behavior

这个方法并不能解决回弹效果的问题.

解决了吗,我也有类似疑问

应该类似这种问题?
https://segmentfault.com/a/1190000014134234

@DeepUse
Edge 浏览器用 overscroll-behavior: none 是有效的。
默认情况下用触摸板拖到底之后还能把整个页面继续拖过头,出现白色背景。给 body 加上 overscroll-behavior: none 之后就不能拖过头了。

按官方说明是可以的(设置为 none
https://developers.google.com/web/updates/2017/11/overscroll-behavior
不过你没说是什么平台, Android 测试是可用的

iOS 让客户端改一个 webview 属性 bounces 可以搞

https://caniuse.com/css-overscroll-behavior
Can I use 里面说 Safari 是不支持这个特性的。
既然说的是移动端,又有空白背景的回弹效果,那大概不是 Android,而是 iOS 了,但是 Safari 不支持,那估计没什么好办法。

ios safari 的毒瘤特性

就是这种 https://stackoverflow.com/questions/49926360/prevent-ios-11-3-overflow-bouncing

iOS

我暂时想到的方案是,设置一个全局变量 canTouchMove 为 false,touchstart 的时候,设置 canTouchMove 为 true,判断一下 scroll,如果是 scroll 动的,返回一个空 return,否则 canTouchMove 为 false.不知道行不行.我的平台是 framework7+vue 开发 app 的 webview.要 Android 和 iOS 都要好用...

position: fixed

使用例如 better-scroll 之类的模拟滚动插件做滚动实现 iOS & Android 端的表现一致性,特别是 iOS 端用 flex 布局可能会滚动焦点不准确导致无法滚动的问题也可以用这种方式解决

不懂就不要乱说了,啥 Safari 毒瘤特性,webview 是继承 scrollview 的,继承 scrollview 的控件都有这种过渡动画。
这个问题的解决办法是让 native 端禁用 bounce 属性,禁止这个页面有弹性动效。

不清楚具体需求,不过只是想消除背景的话可以加个 fixed 元素并铺满屏幕,这样回弹的部分会显示这个元素的背景色

safari 怎么办呢? 我说的是 safari 不是 webview, 毒瘤不毒瘤?

做局部滚动,然后在 document 级别 preventDefault

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服