永发信息网

ScrollView可以监听滚动结束事件吗

答案:2  悬赏:70  手机版
解决时间 2021-01-23 23:09
  • 提问者网友:雪舞兮
  • 2021-01-23 18:59
ScrollView可以监听滚动结束事件吗
最佳答案
  • 五星知识达人网友:十年萤火照君眠
  • 2021-01-23 19:21
scrollView: 1. 介绍scrollView一些属性 1>.要想使用scrollView必须做两件事 1).设置scrollView内容 2).设置contentSize (滚动范围) 2>.其他属性 1). contentOffset(滚动位置) 2). contentInset(额外增加的滚动区域) 3). bounces (设置UIScr...
全部回答
  • 1楼网友:掌灯师
  • 2021-01-23 19:50
原因分析: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的性能方面还是比较好的,有更好的方案后续再更.
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯