js 如何解决移动端 webview 滚动穿透的问题.

2021-05-25 10:13:44 +08:00
 DeepUse

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

3558 次点击
所在节点    JavaScript
18 条回复
codehz
2021-05-25 10:37:11 +08:00
overscroll-behavior
DeepUse
2021-05-25 13:20:47 +08:00
@codehz 这个方法并不能解决回弹效果的问题.
dinjufen
2021-05-25 14:07:39 +08:00
解决了吗,我也有类似疑问
dfkjgklfdjg
2021-05-25 15:27:14 +08:00
ysc3839
2021-05-25 17:16:44 +08:00
@DeepUse
Edge 浏览器用 overscroll-behavior: none 是有效的。
默认情况下用触摸板拖到底之后还能把整个页面继续拖过头,出现白色背景。给 body 加上 overscroll-behavior: none 之后就不能拖过头了。
codehz
2021-05-25 17:16:51 +08:00
@DeepUse 按官方说明是可以的(设置为 none
https://developers.google.com/web/updates/2017/11/overscroll-behavior
不过你没说是什么平台, Android 测试是可用的
chairuosen
2021-05-25 17:20:04 +08:00
iOS 让客户端改一个 webview 属性 bounces 可以搞
ysc3839
2021-05-25 17:21:28 +08:00
https://caniuse.com/css-overscroll-behavior
Can I use 里面说 Safari 是不支持这个特性的。
既然说的是移动端,又有空白背景的回弹效果,那大概不是 Android,而是 iOS 了,但是 Safari 不支持,那估计没什么好办法。
daysv
2021-05-25 18:17:32 +08:00
ios safari 的毒瘤特性
DeepUse
2021-05-25 21:21:32 +08:00
DeepUse
2021-05-25 21:21:59 +08:00
@codehz iOS
DeepUse
2021-05-25 21:26:30 +08:00
@ysc3839 我暂时想到的方案是,设置一个全局变量 canTouchMove 为 false,touchstart 的时候,设置 canTouchMove 为 true,判断一下 scroll,如果是 scroll 动的,返回一个空 return,否则 canTouchMove 为 false.不知道行不行.我的平台是 framework7+vue 开发 app 的 webview.要 Android 和 iOS 都要好用...
PainAndLove
2021-05-25 22:09:19 +08:00
position: fixed
biabia123456
2021-05-25 22:36:18 +08:00
使用例如 better-scroll 之类的模拟滚动插件做滚动实现 iOS & Android 端的表现一致性,特别是 iOS 端用 flex 布局可能会滚动焦点不准确导致无法滚动的问题也可以用这种方式解决
duhb
2021-05-25 23:36:34 +08:00
@daysv #9 不懂就不要乱说了,啥 Safari 毒瘤特性,webview 是继承 scrollview 的,继承 scrollview 的控件都有这种过渡动画。

这个问题的解决办法是让 native 端禁用 bounce 属性,禁止这个页面有弹性动效。
gzzhanghao
2021-05-25 23:38:51 +08:00
不清楚具体需求,不过只是想消除背景的话可以加个 fixed 元素并铺满屏幕,这样回弹的部分会显示这个元素的背景色
daysv
2021-05-26 08:43:28 +08:00
@duhb safari 怎么办呢? 我说的是 safari 不是 webview, 毒瘤不毒瘤?
KuroNekoFan
2021-05-26 12:00:45 +08:00
做局部滚动,然后在 document 级别 preventDefault

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/779018

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX