由于公司接触微信页面较多,
所以一度被微信下拉出黑的这种情况生无可恋,
所以花了较长时间去实践了各种方法(一脸懵逼.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 而造成的事件混淆,
理论上确实能解决出黑底的问题,但依旧不能根除,而且还把下拉刷新刷新的功能搞没了。
就这样吧,这个问题解决办法的寻求将抗日持久....