问题出现在开发H5移动端的时候,发现当内容超过屏幕高度时候无法纵向滚动问题。

检查很多方面,总结了很多博客,分析如下可能原因:
一般我们高度是由内容撑开的,但内容超过屏幕高度时候,可以纵向滚动。
或者在容器外的容器设为固定高度,本身的容器高度由内容撑开,外面的容器设为overflow-y: scroll,也可实现纵向滚动
但本该可以滚动但实际你测试时候用手指不能进行拖动(不算在电脑浏览器打开可以滑轮滚动)。

此时需要检查可能设置了如下属性或方法:
css:

overflow:hidden
或
touch-action: none;

js:
touchstarttouchmovetouchend等事件中的阻止默认事件的原因。
看看有没有写e.preventDefault()

最后笔者踩的坑:
在这里插入图片描述
注释掉就可以解决了。

如果你既想保留阻止下拉刷新又想实现纵向滚动,估计就得对e.targetTouches[0].pageX进行判断了,看看什么时候才该阻止默认事件行为。

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐