在开发一个 app 的部分 webview 功能,把页面滑动到页面的最顶部或最底部时候,页面因为惯性作用,还会往下或往上滚动一段距离后出现空白的背景再回弹.如何禁止这个滚动回弹的效果.
1
codehz 2021-05-25 10:37:11 +08:00 via Android
overscroll-behavior
|
3
dinjufen 2021-05-25 14:07:39 +08:00
解决了吗,我也有类似疑问
|
4
dfkjgklfdjg 2021-05-25 15:27:14 +08:00
|
5
ysc3839 2021-05-25 17:16:44 +08:00
@DeepUse
Edge 浏览器用 overscroll-behavior: none 是有效的。 默认情况下用触摸板拖到底之后还能把整个页面继续拖过头,出现白色背景。给 body 加上 overscroll-behavior: none 之后就不能拖过头了。 |
6
codehz 2021-05-25 17:16:51 +08:00 via Android
@DeepUse 按官方说明是可以的(设置为 none
https://developers.google.com/web/updates/2017/11/overscroll-behavior 不过你没说是什么平台, Android 测试是可用的 |
7
chairuosen 2021-05-25 17:20:04 +08:00
iOS 让客户端改一个 webview 属性 bounces 可以搞
|
8
ysc3839 2021-05-25 17:21:28 +08:00
https://caniuse.com/css-overscroll-behavior
Can I use 里面说 Safari 是不支持这个特性的。 既然说的是移动端,又有空白背景的回弹效果,那大概不是 Android,而是 iOS 了,但是 Safari 不支持,那估计没什么好办法。 |
9
daysv 2021-05-25 18:17:32 +08:00
ios safari 的毒瘤特性
|
10
DeepUse OP |
12
DeepUse OP @ysc3839 我暂时想到的方案是,设置一个全局变量 canTouchMove 为 false,touchstart 的时候,设置 canTouchMove 为 true,判断一下 scroll,如果是 scroll 动的,返回一个空 return,否则 canTouchMove 为 false.不知道行不行.我的平台是 framework7+vue 开发 app 的 webview.要 Android 和 iOS 都要好用...
|
13
PainAndLove 2021-05-25 22:09:19 +08:00
position: fixed
|
14
biabia123456 2021-05-25 22:36:18 +08:00
使用例如 better-scroll 之类的模拟滚动插件做滚动实现 iOS & Android 端的表现一致性,特别是 iOS 端用 flex 布局可能会滚动焦点不准确导致无法滚动的问题也可以用这种方式解决
|
15
duhb 2021-05-25 23:36:34 +08:00 via iPhone
@daysv #9 不懂就不要乱说了,啥 Safari 毒瘤特性,webview 是继承 scrollview 的,继承 scrollview 的控件都有这种过渡动画。
这个问题的解决办法是让 native 端禁用 bounce 属性,禁止这个页面有弹性动效。 |
16
gzzhanghao 2021-05-25 23:38:51 +08:00 via iPhone
不清楚具体需求,不过只是想消除背景的话可以加个 fixed 元素并铺满屏幕,这样回弹的部分会显示这个元素的背景色
|
18
KuroNekoFan 2021-05-26 12:00:45 +08:00
做局部滚动,然后在 document 级别 preventDefault
|