记录一次ios下fixed区域中滚动内容滑动到底部/顶部后不可滑动的问题修复【转载】

如题,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';
            }
        },

————————————————
版权声明:本文为CSDN博主「蛋蛋fighting哈湫」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u012439689/article/details/122256755

 

 

方法二:

/** 解决 ios浏览器页面滚动到底部或顶部后 导致页面局部滑动失效的问题*/
    function iosTrouchFn () {
        var ios = navigator.userAgent.indexOf('iPhone'); // 判断是否为ios
        if (ios !== -1) { // ios下运行
            var el = document.querySelector('body'); // el -- 需要滑动的元素
            el.addEventListener('touchmove', function (e) {
                if (el.offsetHeight < el.scrollHeight)  e.isSCROLL = true;
            });
            document.body.addEventListener('touchmove', function (e) {
                if (!e.isSCROLL) e.preventDefault(); // 阻止默认事件(上下滑动)
            });
        }
    }

 

posted @ 2022-06-06 14:35  小猪冒泡  阅读(902)  评论(0编辑  收藏  举报