移动端弹窗滚动锁定需同时设置html和body样式并记录恢复scrollY,禁用touchmove须精准作用于非弹窗区域,iOS键盘问题需结合scrollIntoView与延迟回滚,overscroll-behavior仅防弹性穿透。移动端弹窗时页面还在滚动?body 的 overflow 不够用直接设 body { overflow: hidden } 看似能锁住背景,但实际在 iOS Safari 和部分 Android 浏览器里根本无效------滚动惯性、地址栏收起/展开、键盘弹出都会触发底层页面滚动。真正起作用的是对 html 和 body 同时加限制,并配合 position: fixed 重置滚动位置。实操建议:弹窗打开时,先记录当前 scrollY 值:const scrollTop = window.scrollY给 html 加 style="position: fixed; width: 100%; top: -${scrollTop}px",把整个视口"钉住"并回滚到原位置同时设 body { overflow: hidden } 防止键盘唤起后内容上顶关闭弹窗时,恢复 html.style.position 和 body.style.overflow,再调用 window.scrollTo(0, scrollTop)touchmove 事件阻止太粗暴,会干掉所有手势用 event.preventDefault() 拦截 touchmove 是常见做法,但一旦绑定在 document 上,连弹窗内的滑动轮播、下拉刷新、甚至输入框光标拖动都会失效。它不是"锁背景",而是"禁一切触摸滚动"。更安全的做法是只拦截非弹窗区域的滚动:立即学习"前端免费学习笔记(深入)";监听 touchmove 时,检查 event.target 是否在弹窗容器内(比如 event.target.closest('.modal'))不在弹窗内才调用 event.preventDefault()必须搭配 { passive: false } 注册事件,否则 Safari 会忽略 preventDefault别忘了在弹窗关闭时移除该监听,避免内存泄漏iOS 键盘弹出导致背景"闪一下"或自动滚动到顶部这是 iOS WebKit 的经典 Bug:软键盘唤起时,浏览器会尝试把聚焦元素滚动进可视区,结果把被锁住的 html 又强行拖动了。单纯靠 CSS 或 JS 锁定挡不住这个行为。 Fotor AI Image Generator Fotor 平台的 AI 图片生成器
相关推荐
消失的旧时光-19432 小时前
SQL 第五篇:SQL 如何真正接入 Spring Boot 项目(企业 Mapper 分层实战)测试员周周8 小时前
【AI测试智能体】为什么传统测试方法对智能体失效?dfdfadffa8 小时前
如何用模块化方案组织一个可扩展的前端组件库项目2301_812539678 小时前
SQL中如何高效实现分组数据的批量更新_利用窗口函数与JOINRSTJ_16258 小时前
PYTHON+AI LLM DAY THREETY-NINE2501_901200538 小时前
如何实现SQL存储过程存储过程参数标准化_统一命名规范运气好好的9 小时前
Golang怎么用embed嵌入SQL文件_Golang如何将SQL迁移文件嵌入Go程序统一管理【技巧】AC赳赳老秦9 小时前
政企内网落地:OpenClaw 离线环境深度适配方案,无外网场景下本地化模型对接与全功能使用星越华夏9 小时前
python 将相对路径变成绝对路径念何架构之路9 小时前
MySql常见ORM