问题描述:
被遮挡的页面是一个有滚动条的页面。覆盖在上方的是一个有遮罩层的弹框。弹框内部存在滚动条。
在ios机型下,当不做任何处理时,点击遮罩层对应的位置,会触发被遮挡页面的click操作。并且弹框内部无法进行正确的滚动,而是直接触发了被遮挡页面的滚动操作。
解决方案:
- 如果不介意滑动遮罩层,仍可以滚动被遮挡页面。处理方式相对比较简单, 可以直接在遮罩层上阻止touchmove操作的冒泡行为就可以了。此时弹框内部可以正确滚动,并且点击不会触发底部页面的click事件。
touchmove(e) {
e.stopPropagation()
}
- 如果要禁止被遮挡页面的滚动事件,相对就复杂一点。需要禁止所有的事件,然后单独对弹框内部进行处理