解决移动端有纵向滚动条但是不能滚动的问题
解决移动端有纵向滚动条但是不能滚动的问题
·
问题出现在开发H5移动端的时候,发现当内容超过屏幕高度时候无法纵向滚动问题。
检查很多方面,总结了很多博客,分析如下可能原因:
一般我们高度是由内容撑开的,但内容超过屏幕高度时候,可以纵向滚动。
或者在容器外的容器设为固定高度,本身的容器高度由内容撑开,外面的容器设为overflow-y: scroll
,也可实现纵向滚动
但本该可以滚动但实际你测试时候用手指不能进行拖动(不算在电脑浏览器打开可以滑轮滚动)。
此时需要检查可能设置了如下属性或方法:
css:
overflow:hidden
或
touch-action: none;
js:
touchstart
、touchmove
或touchend
等事件中的阻止默认事件的原因。
看看有没有写e.preventDefault()
。
最后笔者踩的坑:
注释掉就可以解决了。
如果你既想保留阻止下拉刷新又想实现纵向滚动,估计就得对e.targetTouches[0].pageX
进行判断了,看看什么时候才该阻止默认事件行为。
更多推荐
已为社区贡献7条内容
所有评论(0)