标签:tps 故事 是的 100% dao you 定位 属性 bar
故事的起因是,在一个多列表的页面上,页面在iOS11,跟iOS10中会发生页面卡住,不能进行滚动。
然后就怀疑是自己的样式写的出了问题,就一直排查定位元素的样式,怎么都找不到问题所在。
但还是本着追根溯源的精神,定位到根元素的样式上有一个
-webkit-overflow-scrolling: touch;
的样式属性;然后查了一下该属性:
-webkit-overflow-scrolling
属性控制元素在移动设备上是否使用滚动回弹效果.
在移动端上,在你用overflow-y:scorll属性的时候,你会发现滚动的效果很很生硬,很慢,这时候可以使用-webkit-overflow-scrolling:touch这个属性,让滚动条产生滚动回弹的效果,就像ios原生的滚动条一样流畅。
但是的但是,-webkit-overflow-scrolling:touch这个属性真的是超级神坑,比如:
<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。我也只是按照自己的思路从新整理一下。 侵删。
移动端丨-webkit-overflow-scrolling:touch属性导致页面卡住
标签:tps 故事 是的 100% dao you 定位 属性 bar
原文地址:https://www.cnblogs.com/hrone/p/10143960.html