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

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

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


同样遇到了这个问题


终极解决答案... 经过一年多的探索... 给大家一个答案... 我也是日了狗了...
<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


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


300毫秒带来的问题


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

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

  overflow-y: hidden;

https://bumfo.github.io/dialog.html


禁止事件冒泡


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


禁用弹框下页面滚动

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

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

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

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

document.body.style.overflow = 'hidden';

http://stackoverflow.com/questions/2469529/how-to-disable-scrolling-th...


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

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

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

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

Fastclick?

【热门文章】
【热门文章】