故事的起因是,在一个多列表的页面上,页面在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给渲染模块使用。我们也就只能解决到这了。

移动端-webkit-overflow-scrolling:touch属性导致页面卡住相关推荐

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

    起因 起因 -webkit-overflow-scrolling 问题 解决方案: 方案一 方案二 思考为什么会出现这个问题 总结 故事的起因是,在一个多列表的页面上,页面在iOS11,跟iOS10中 ...

  2. css中overflow:hidden的属性 可能会导致js下拉菜单无法显示

    css中overflow:hidden属性导致ExtJS中无法显示下拉滚动条 overflow属性: visible 默认.内容不会被修剪,会呈现在元素之外. hidden 内容会被修剪,但是浏览器不 ...

  3. [Web 前端] inline-block元素设置overflow:hidden属性导致相邻行内元素向下偏移

    cp from : https://blog.csdn.net/iefreer/article/details/50421025 在表单修改界面中常会使用一个标签.一个内容加一个修改按钮来组成单行界面 ...

  4. inline-block元素设置overflow:hidden属性导致相邻行内元素向下偏移

    在表单修改界面中常会使用一个标签.一个内容加一个修改按钮来组成单行界面,如下所示: 那么在表单总长度受限的情况下,当中间的邮箱名称过长时,会遮盖到旁边的按钮. 我们可以把中间邮箱设定最大宽度,然后对于 ...

  5. 移动端登录页样式错乱_Web前端导致页面css样式混乱的原因问题,我和小伙伴们惊呆了...

    ## **css常用技巧** 本文都时再工作中用得比较多的Css,还有遇到的一些不长记性的问题,一起来看看这些技巧吧. 1. **实现组件的自动换行排布:** flex-wrap: wrap; 使列表 ...

  6. webkit的几个属性

    -webkit-text-size-adjust 1.当样式表里font-size<12px时,中文版chrome浏览器里字体显示仍为12px,这时可以用 html{-webkit-text-s ...

  7. 智能安全实验室-杀马(Defendio) 2.5.0.426 :解决因日期超过28日(29/30/31)出现的“无效属性”导致杀马无法启动的问题;...

    智能安全实验室-杀马(Defendio) 2.5.0.426 :解决因日期超过28日(29/30/31)出现的"无效属性"导致杀马无法启动的问题: 详细信息请访问:http://u ...

  8. 在移动端设置overflow:hidden禁止滚动的解决方法

    在移动端设置overflow:hidden禁止滚动的解决方法 参考文章: (1)在移动端设置overflow:hidden禁止滚动的解决方法 (2)https://www.cnblogs.com/ko ...

  9. disable属性导致后台接收值为null解决方法

    disable属性导致后台接收值为null 类似问题 解决办法 1.在提交的时候将disabled属性remove掉((加载页面的时候设置表单属性disabled=true,提交表单的时候设置表单属性 ...

最新文章

  1. CTO集体怒吼:我到底要不要继续写代码(上篇)
  2. FluxSink实例及解析
  3. 流程控制--for序列
  4. 如何将html表单转换成url,JS表单传值和URL编码转换
  5. RISC-V应用创新大赛开放报名啦!
  6. LiveVideoStack线上交流分享 ( 四 ) —— 面向QoE的感知视频编码
  7. 异步编程Promise、Generator和Async
  8. css常用属性总结:颜色和单位
  9. 01_MySQL基础课堂笔记
  10. Python Levenshtein(两个文本比较,两个字符串比较)
  11. 9 QM配置-检验计划配置-维护检验类型
  12. 富文本框让最大四百像素_富文本框的使用
  13. Jupyter Lab——无法显示matplotlib绘制的图像
  14. Gitbook 常用命令
  15. Android Track的play流程(三十二)
  16. 数据量大的sql怎么做优化_南浔区360优化怎么做,百度关键词优化_万推霸屏
  17. CuteFTP使用手册
  18. 第一章 教育基础(06 小学课程)
  19. model.compile
  20. Android 插件仓库

热门文章

  1. git报错fatal: unable to access ‘https://github.com/stephaniedurand/SeisTomoPy_V3.git/‘: gnutls_handsha
  2. 51单片机(入门保姆级教程)——点亮一个LED灯
  3. 深度强化学习-基于价值学习的高级技巧(五-1)
  4. FFmpeg解码内存G711A
  5. 数据从数据库中分离脱机
  6. 半路出家自学JAVA!非科班出身也能做程序员?
  7. 李明老师关于说话人识别和语种识别的总结
  8. 使用node.js搭建简单服务器
  9. 域名未及时续费的后果、常见原因及建议
  10. memblock初始化过程中fdt mem处理