屏蔽微信下拉出黑底现象

时间:2016-09-13 13:20:47   收藏:0   阅读:431

由于公司接触微信页面较多,

所以一度被微信下拉出黑的这种情况生无可恋,

所以花了较长时间去实践了各种方法(一脸懵逼.jpg)

好吧,经过各种傻逼的方法尝试后,发觉竟然还是可以简单解决的,一脸憋屈...

普遍流传的方法是屏蔽掉 body 的 touchstart 或 touchmove 事件,但也会让所有滚动不可用,只适用部分页面

所以我就把重心放在了如何让滚动依旧可用上,乃至屏蔽所有的事件自写一个滚动容器(弹性拖动和避免卡顿要疯...)

而后来发现,直接屏蔽掉当 scrollTop 在顶部时的 touchmove 不就好了吗,真是走了好多弯路

function stopDrop(stillCanScroll) {
  var lastY;
  $("body").off().on(‘touchstart.stop‘, function(event) {
    lastY = event.originalEvent.changedTouches[0].clientY;
  }).on(‘touchmove.stop‘, function(event) {
    var y = event.originalEvent.changedTouches[0].clientY;
    var st = $(stillCanScroll).scrollTop();
    // 向上滚动且滚动条位于顶部,屏蔽事件
    if (y > lastY && st < 5) {
      event.preventDefault();
      return false;
    }
    lastY = y;
  });
}

该怎么去评价这段代码吗,反正不高效就对了,

正在实践多个 stillCanScroll 的情况,但又实在害怕检测该元素 touchstart 而造成的事件混淆,

理论上确实能解决出黑底的问题,但依旧不能根除,而且还把下拉刷新刷新的功能搞没了。

就这样吧,这个问题解决办法的寻求将抗日持久....

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!