V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
DeepUse
V2EX  ›  JavaScript

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

  •  
  •   DeepUse · 2021-05-25 10:13:44 +08:00 · 3870 次点击
    这是一个创建于 1284 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    18 条回复    2021-05-26 12:00:45 +08:00
    codehz
        1
    codehz  
       2021-05-25 10:37:11 +08:00 via Android
    overscroll-behavior
    DeepUse
        2
    DeepUse  
    OP
       2021-05-25 13:20:47 +08:00
    @codehz 这个方法并不能解决回弹效果的问题.
    dinjufen
        3
    dinjufen  
       2021-05-25 14:07:39 +08:00
    解决了吗,我也有类似疑问
    dfkjgklfdjg
        4
    dfkjgklfdjg  
       2021-05-25 15:27:14 +08:00
    ysc3839
        5
    ysc3839  
       2021-05-25 17:16:44 +08:00
    @DeepUse
    Edge 浏览器用 overscroll-behavior: none 是有效的。
    默认情况下用触摸板拖到底之后还能把整个页面继续拖过头,出现白色背景。给 body 加上 overscroll-behavior: none 之后就不能拖过头了。
    codehz
        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 测试是可用的
    chairuosen
        7
    chairuosen  
       2021-05-25 17:20:04 +08:00
    iOS 让客户端改一个 webview 属性 bounces 可以搞
    ysc3839
        8
    ysc3839  
       2021-05-25 17:21:28 +08:00
    https://caniuse.com/css-overscroll-behavior
    Can I use 里面说 Safari 是不支持这个特性的。
    既然说的是移动端,又有空白背景的回弹效果,那大概不是 Android,而是 iOS 了,但是 Safari 不支持,那估计没什么好办法。
    daysv
        9
    daysv  
       2021-05-25 18:17:32 +08:00
    ios safari 的毒瘤特性
    DeepUse
        11
    DeepUse  
    OP
       2021-05-25 21:21:59 +08:00
    @codehz iOS
    DeepUse
        12
    DeepUse  
    OP
       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
        13
    PainAndLove  
       2021-05-25 22:09:19 +08:00
    position: fixed
    biabia123456
        14
    biabia123456  
       2021-05-25 22:36:18 +08:00
    使用例如 better-scroll 之类的模拟滚动插件做滚动实现 iOS & Android 端的表现一致性,特别是 iOS 端用 flex 布局可能会滚动焦点不准确导致无法滚动的问题也可以用这种方式解决
    duhb
        15
    duhb  
       2021-05-25 23:36:34 +08:00 via iPhone
    @daysv #9 不懂就不要乱说了,啥 Safari 毒瘤特性,webview 是继承 scrollview 的,继承 scrollview 的控件都有这种过渡动画。

    这个问题的解决办法是让 native 端禁用 bounce 属性,禁止这个页面有弹性动效。
    gzzhanghao
        16
    gzzhanghao  
       2021-05-25 23:38:51 +08:00 via iPhone
    不清楚具体需求,不过只是想消除背景的话可以加个 fixed 元素并铺满屏幕,这样回弹的部分会显示这个元素的背景色
    daysv
        17
    daysv  
       2021-05-26 08:43:28 +08:00
    @duhb safari 怎么办呢? 我说的是 safari 不是 webview, 毒瘤不毒瘤?
    KuroNekoFan
        18
    KuroNekoFan  
       2021-05-26 12:00:45 +08:00
    做局部滚动,然后在 document 级别 preventDefault
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   930 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 21:39 · PVG 05:39 · LAX 13:39 · JFK 16:39
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.