• 记录一次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(); // 阻止默认事件(上下滑动)
                });
            }
        }
  • 相关阅读:
    微软一站式示例代码库(中文版)2010年12月10日更新
    微软一站式示例代码库(中文版)2011年1月12日更新
    微软一站式示例代码库 MSDN 官方论坛今天正式上线
    微软一站式示例代码浏览器 第二版 CTP发布
    两边固定中间子适应的流式布局
    不使用第三个变量交换两个数字
    身份证号码15位转18位 C#实现
    利用AspNetPager分页
    C#面向对象高级语法(一)
    String.Empty、string=”” 和null的区别
  • 原文地址:https://www.cnblogs.com/xiaozhumaopao/p/16348136.html
Copyright © 2020-2023  润新知