移动页面滚动穿透如何解决

在安卓系统的webview下写的页面,各种版本包括4.4,当弹出一个半透明全屏的弹框后,这时在PC上滚动条应该是不可用的,但是在webview下,在弹框上用手指滑动,弹框下面的页面是会跟着动的。不知道有没有人能解决,去谷歌也不知道用什么关键词,百度真是坑爹 = =! 求大神指点

阅读 36k
14 个回答

终极解决答案... 经过一年多的探索... 给大家一个答案... 我也是日了狗了...
<body> <ui-view class="container" style="display: block; height: 100%; overflow: auto"></ui-view> <div id="showDetail" class="show-detail" ng-show="showDetail" ng-include="'showDetail.html'"></div> </body>
这里 ui-view这个标签是正常显示的,点击上面的元素后弹出showDetail。
一次无意间的测试,在ui-view的标签上加了一个overflow:auto 滚动就不穿透了...
如果不在对应的需要滚动的容器上,加这个样式的话,最后滚动条会在body上。
射了这个样式的话 window.on('scroll') 也会失效。这个时候要监听container上的scroll

禁用弹框下页面滚动

.alpha {
    height: 100%;
    overflow: hidden;
    position: relative;
}

.alpha body {
    height: 100%;
    overflow: hidden;
}

当你遮盖弹出的时候或者隐藏的时候让 html 切换 class alpha

$('html').toggleClass('alpha');

同样遇到了这个问题

300毫秒带来的问题

我咋没觉得这是个问题呢,我觉得挺好的,不就应该这样吗

wap下我是这样处理的,还没嵌入到webview验证。

点击弹框的时候,给html,body加上一个class,控制样式为:

  overflow-y: hidden;

Fastclick?

300ms事件响应时间问题,给上层方法事件传递延时300+,之前项目中遇到过,其中有这样一个解决方案,可以试试

当弹出 弹框的时候,给body设置overflow: hidden;

$('body').css('overflow','hidden');

弹框消失的时候,overflow: initial;

$('body').css('overflow','initial');
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏