如题,ios多机型,h5的页面制作的一个展示列表,外部采用fixed布局固定显示了表头筛选项的一些东西,然后中间是内容可滚动区,如下图,然后ios的机型会出现的问题就是,滚动到顶部或者底部再用力划一下的话(等到内部滚动区域滚动条消失),滚动就会被卡住,滚不动了,看了很多文章和解决方案,都没有解决我的问题,后来发现每次卡住都是内部滚动条消失之后出现的,由于IOS本身具有的橡皮筋特效~同时参考了这篇推文深入研究-webkit-overflow-scrolling:touch及ios滚动 - 夏大师 - 博客园中关于ios scroll-view渲染的一些分析,猜测是内部的内容scroll-view在滚动时候,顶部或者底部到了之后,渗透到了下层的scroll-view(一般整页面fixed布局就会直接到body层)然后卡住不动的阶段应该是在body层反复摩擦。。。

按照这个猜想,我首先给整个body加了overflow:hidden,禁用了全部的滚动效果,可以实现,但是这样太简单粗暴了,而且会影响整个系统中的所有页面,因此继续优化,我的方案是,监听滚动,橡皮筋特效触发时候,滚动值相对于可滚动区域是负值或者大于滚动区域高度的值针对这个现象,监听发现滚动值相对于滚动区域dom区间<=0 (需要有=0的判断,否则顶部不生效)或者 大于容器高度时,对body设置overflow:hidden,至此,问题解决,给自己点个赞~

demo源码方案如下,提供给有需要的小伙伴参考

vue中的写法哈~

// 页面添加滚动监听
        document.getElementById('你的容器id').addEventListener('scroll', this.handleScroll);

// 监听事件

        handleScroll() {
            const scrollTop =  document.getElementById('你的容器id').scrollTop;
            if (scrollTop <= 0 || scrollTop > document.getElementById('你的容器id').offsetHeight) {
                document.body.style.overflow = 'hidden';
            } else {
                document.body.style.overflow = 'auto';
            }
        },

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐