移动端丨-webkit-overflow-scrolling:touch属性导致页面卡住

起因

 

 

故事的起因是,在一个多列表的页面上,页面在iOS11,跟iOS10中会发生页面卡住,不能进行滚动。

然后就怀疑是自己的样式写的出了问题,就一直排查定位元素的样式,怎么都找不到问题所在。

但还是本着追根溯源的精神,定位到根元素的样式上有一个-webkit-overflow-scrolling: touch;的样式属性;然后查了一下该属性:

-webkit-overflow-scrolling

属性控制元素在移动设备上是否使用滚动回弹效果.

  • auto: 使用普通滚动, 当手指从触摸屏上移开,滚动会立即停止。
  • touch: 使用具有回弹效果的滚动,当手指从触摸屏上移开,内容会继续保持一段时间的滚动效果。继续滚动的速度和持续的时间和滚动手势的强烈程度成正比。同时也会创建一个新的堆栈上下文。

在移动端上,在你用overflow-y:scorll属性的时候,你会发现滚动的效果很很生硬,很慢,这时候可以使用-webkit-overflow-scrolling:touch这个属性,让滚动条产生滚动回弹的效果,就像ios原生的滚动条一样流畅。

问题

但是的但是,-webkit-overflow-scrolling:touch这个属性真的是超级神坑,比如:

  • 在safari上,使用了-webkit-overflow-scrolling:touch之后,页面偶尔会卡住不动。(中招)
  • 在safari上,点击其他区域,再在滚动区域滑动,滚动条无法滚动的bug。
  • 通过动态添加内容撑开容器,结果根本不能滑动的bug。(中招)
  • 滚动中 scrollTop 属性不会变化
  • 手势可穿过其他元素触发元素滚动
  • 滚动时暂停其他 transition

解决方案:

方案一

<div id="app" style="-webkit-overflow-scrolling: touch;
">
    <div style="min-height:101%"></div>
</div>

方案二

<div id="app" style="-webkit-overflow-scrolling: touch;
">
    <div style="height:calc(100%+1px)"></div>
</div>

方法就是在webkit-overflow-scrolling:touch属性的下一层子元素上,将height加1%或1px。从而主动触发scrollbar。

思考为什么会出现这个问题

Safari对于overflow-scrolling用了原生控件来实现。对于有-webkit-overflow-scrolling的网页,会创建一个UIScrollView,提供子layer给渲染模块使用。我们也就只能解决到这了。

总结

不得不感叹,这些神奇的黑魔法,看的奇奇怪怪但是真实 的解决了实际的问题,毕竟css本身也是就是黑魔法本黑了,更不要说移动端这个天坑了。 最后感谢一下 博主 夏大师的总结;原链接在此https://www.cnblogs.com/xiahj/p/8036419.html。我也只是按照自己的思路从新整理一下。 侵删。

posted @   Hrone  阅读(14059)  评论(1编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示