关于ScrollView或者tableview,请问是否可以监听滚动停止事件
展开全部
原因分析:ios的webview内核设定了其在进行momentumscrolling(弹性滚动)时,会停止所有的事件响应及DOM操作引起的页面渲染(亲测),故onscroll不能实时响应曾做兼容方案:使用ontouchmove去替代nscroll,虽然能更频繁的触发事件,但是这边的项目需求是实时响应滚动事件的同时,还要对页面元素进行重定位的DOM操作,由上述原因可知,在滚动过程中,页面会停止一切关于DOM方面的操作,所以若使用ontouchmove去实现的话,在按住屏幕进行滑动的时候,屏幕会出现元素抖动的情况(事件触发与DOM操作间具有几十毫秒的时间差),兼容失败使用iscroll的probe版本,该版本能实时探查到滚动的距离,但该钩子函数是实时去关注requestAnimationFrame下的状态,所以对浏览器的版本性能消耗很大,加上react的DOM操作,安卓机根本动不了,兼容失败使用swiper插件,在启动freeMode模式时模拟原生的弹性滚动(swiper模拟原生滚动的方案能兼容较多的安卓机型不出现bug,推荐),因为swiper没有实时监听滚动位置的功能,故我监听滚动开始及结束后的事件,通过setInterval及一些计算去实现滚动条的监听,但因为react元素的变化量比较大,导致swiper在移动端时对父容器的计算速率达到了一个瓶颈,依旧出现很卡顿的现象,兼容失败fallback方案,安卓端使用原生onscroll实现,ios直接加载全部子元素,毕竟ios的性能方面还是比较好的,有更好的方案后续再更.
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询