移动端弹出层滚动穿透问题总结
移动端弹出层(简称layer)时,层内有大量文字需要滚动,但是背景层(简称body)会随着layer的滚动而滚动,用户体验较差。参考了网上的一些资料,总结解决方案如下:
.scrollFix{
height: 100%;
overflow: hidden;
position: relative;
}
.scrollFix body{
height: 100%;
overflow: hidden;
}
弹出层前:
//防止body层向下滚动后出现内容显示不全的问题
$('html,body').animate({scrollTop: 0}, 100);
$('html').addClass('scrollFix');
弹出层关闭后(一般是层的关闭回调):
$('html').removeClass('scrollFix');
还有一种禁用背景层touchmove事件的方法
function ShowLayer(){
bgDom.ontouchmove=function(e){
e.preventDefault && e.preventDefault();
e.returnValue=false;
e.stopPropagation && e.stopPropagation();
return false;
}
}
或者
function fScrollFix(e){
e.preventDefault();
e.stopPropagation();
}
bgDom.addEventListener('touchmove',fScrollFix,false);
function CloseLayer()
{
bgDom.ontouchmove=function(e){
e.preventDefault && e.preventDefault();
e.returnValue=true;
e.stopPropagation && e.stopPropagation();
return true;
}
}
或者
bgDom.removeEventListener('touchmove',fScrollFix,false);
bgDom为背景层dom对象,此方案笔者实验未成功
参考:http://segmentfault.com/q/1010000003089816
http://www.w3cfuns.com/article-5600528-1-1.html
http://zhangzhaoaaa.iteye.com/blog/2105145
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具