这篇文章主要介绍了css如何防止页面滑动穿透,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

问题描述:

移动端当有 fixed 遮罩背景和弹出层时,在屏幕上滑动能够滑动背景下面的内容,这就是著名的滚动穿透问题。

示例demo:

样式:

.box{

width: 100%;

height: 100%;

position: relative;

}

.dialog{

width: 100%;

height: 100%;

position: fixed;

left: 0;

top: 0;

background: rgba(0,0,0,0.4);

}

.dia-con {

width: 40vw;

height: 38vw;

background: white;

margin: 30vh auto;

}

结构:

1测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

2测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

4测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

5测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

6测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

7测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

8测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字测试文字

内容

我知道了

在手机页面运行上面代码如图所示: 在灰色的遮罩上滑动的时候 下面的 “测试文字” 也会跟着滑动。

解决方案一:

阻止顶层 遮罩的默认行为。阻止冒泡。

示例demo:

.modals button{width:100%;margin:0 auto;height:auto;line-height:30px;border:1px solid #4185F3;color:#fff;font-size:14px;background:#4185F3;margin:0 auto}

.modals-body{padding:30px 15px;font-size:10px;color:#666;text-align:center;background:#fff}

.sliders{cursor:not-allowed;display:block;position:fixed;overflow:hidden;z-index:103;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:rgba(20,20,20,.8)}

.modals{overflow-y:auto;max-height:95%;font-size:16px;z-index:103;border-radius:5px;background:#fff;width:50%;color:#333;display:block;box-shadow:0 0 3px rgba(0,0,0,.1);position:fixed;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}

用户信息丢失,请先登录

确定

for(var i = 0;i<=30;i++){

$(".list").append("

BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB

");

}

//阻止防止滚动、缩放。

$(".sliders,.modals").on("touchmove",function(event){

event.preventDefault();

});

$(".btns").on("click",function(){

$(".sliders,.modals").remove();

});

运行效果:

解决方案二:

首先设置 body 的overflow : hidden; 这样超出部分 就不会滑动。当 遮罩 消失时,在设置body的 overflow: initial; 或者设置为 scroll即可

示例demo:

body{overflow:hidden;}

.modals button{width:100%;margin:0 auto;height:auto;line-height:30px;border:1px solid #4185F3;color:#fff;font-size:14px;background:#4185F3;margin:0 auto}

.modals-body{padding:30px 15px;font-size:10px;color:#666;text-align:center;background:#fff}

.sliders{cursor:not-allowed;display:block;position:fixed;overflow:hidden;z-index:103;top:0;right:0;bottom:0;left:0;width:100%;height:100%;background:rgba(20,20,20,.8)}

.modals{overflow-y:auto;max-height:95%;font-size:16px;z-index:103;border-radius:5px;background:#fff;width:50%;color:#333;display:block;box-shadow:0 0 3px rgba(0,0,0,.1);position:fixed;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}

用户信息丢失,请先登录

确定

//解决方案一:

// for(var i = 0;i<=30;i++){

// $(".list").append("

BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB

");

// }

// //阻止防止滚动、缩放。

// $(".sliders,.modals").on("touchmove",function(event){

// event.preventDefault();

// });

// $(".btns").on("click",function(){

// $(".sliders,.modals").remove();

// });

// 解决方案 二:

for(var i = 0;i<=30;i++){

$(".list").append("

BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB

");

}

$(".btns").on("click",function(){

$(".sliders,.modals").remove();

//关键代码

$("body").css("overflow-y","initial");

});

总结:

最简单的解决方案:body{

overflow: hidden;

}

在body上增加这个样式即可禁止滑动。

css3层级穿透,css页面滑动穿透的两种解决办法相关推荐

  1. android中view手势滑动冲突的两种解决方法

    android中view手势滑动冲突的解决方法,主要解决方法有两种,外部和内部拦截.有需要的可以参考下. Android手势事件的冲突跟点击事件的分发过程息息相关,由三个重要的方法来共同完成,分别是: ...

  2. dz手机版空白显示index.php,discuz x3.3安装插件时页面出现空白有两种解决方法

    一.下载你所用的discuz程序版本的function_cloudaddons.php覆盖一下就可以恢复 解决DiscuzX3.1 X3.2安装插件空白 第一步:把你所对应的安装包版本解压一下到桌面. ...

  3. 前端开发审查元素时CSS样式有个横线(该CSS样式定义后无效) 的解决办法

    问题概述 关于这个问题,博主是在前端开发,样式调试的时候遇到的, 进行盒模型,CSS Debugger调试时,遇到样式设值后不可用的情况! 如下图: 解决办法 左看右看,上看下看,最终发现是前面在编码 ...

  4. html如何将图片做成六边形,css画正六边形的两种方法

    说下两种css 制作正六边形的方法. 先看一下结果: 在之前要先了解一下正六边形内角和边的关系,正六边形的每个内角是60deg,如图(√3其实是根号3): 方法一:原理把正六边形分成三部分,左中右分别 ...

  5. html中怎么写正六边形,如何用css画正六边形?用css画正六边形的两种方法(代码实例)...

    本章给大家介绍如何用css画正六边形?用css画正六边形的两种方法(代码实例).有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 在之前要先了解一下正六边形内角和边的关系,正六边形的每个 ...

  6. 如何将横向滚动条加粗css,css实现横向滚动条的两种方式(代码实例)

    本章给大家介绍用css实现横向滚动条的两种方式.有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. html代码: 全部 Adobe 微软 会计 绘画 Adobe 微软 会计 绘画 一. ...

  7. css之文本两端对齐的两种解决方法

    css之文本两端对齐的两种解决方法 参考文章: (1)css之文本两端对齐的两种解决方法 (2)https://www.cnblogs.com/wl0804/p/11265225.html 备忘一下.

  8. php 修改css 不生效,HTML外部引用CSS文件不生效原因分析及解决办法

    本文主要给大家介绍html外部引用css文件不生效的原因分析及解决办法,本文介绍的非常详细,具有参考借鉴价值,感兴趣的朋友一起学习吧 作为一个前端小白,鼓捣了几天前端..今天突然发现我深信不疑的东西, ...

  9. Html设置表格撑开,CSS教程:表格不被撑开的解决办法

    CSS教程:表格不被撑开的解决办法 2009-10-21 eNet&Ciweek 今天在做一个用户留言列表的时候,用到了表格.用户名为英文字符时,就会把固定宽度的单元格撑开.之前也有遇到过.解 ...

最新文章

  1. vue中使用promise
  2. Vue 里的$如何理解
  3. 【Unity3D技巧】一个简单的Unity-UI框架的实现
  4. thinkphp5项目--个人博客(六)
  5. express-winston 库的学习笔记
  6. linux每天一小步---sed命令详解
  7. 【Python学习】win10+Anaconda3环境,安装phthon第三方库Jieba
  8. android最简单存储数据结构,什么是存储要在多个Android设备上共享的同步数据的最佳数据结构?...
  9. 通过图像的指针读取图像
  10. Kettle_Spoon如何将MySQL数据抽取到ES
  11. matlab画柱状图斜线,matlab柱状图斜线填充
  12. 加速数据无限超高速空间免费虚拟主机无限大小 支持SSL
  13. steam的游戏id怎么查?
  14. 用户使用什么命令访问远程计算机,远程桌面连接命令是什么 怎么使用命令连接远程服务器...
  15. 字符串的常用方法和常用类
  16. 裂变海报设计的落地干货,为什么海报在裂变活动中这么重要?
  17. web靶场 --- sqli-labs
  18. 简明GISer Python学习指南
  19. 持续集成Jenkins+Gitlab实现持续集成
  20. 预防防御鸡呼吸道疾病 鸡吃啥药防治呼吸道感染

热门文章

  1. vivo又有新机跑分曝光 机海战术要来了?
  2. 库克看下!罗永浩深夜再谈收购苹果:还需要点时间
  3. 实锤了!锤子卖身字节跳动 Smartisan OS官微透露了信息
  4. 苹果新闻订阅服务Apple News +推出48小时获得逾20万用户
  5. 华为P30 Pro外观无悬念:双曲面水滴屏 屏占比超高
  6. iPhone SE 2渲染图曝光:采用刘海全面屏
  7. 拳王公社:虚拟资源项目怎么做?如何操作赚钱?最新操作方法
  8. 虚拟资源拳王公社:小白从0到1搭建个人私域流量池的实操方法,6招玩转流量裂变法
  9. Web开发之四:前后端开发模式探讨
  10. 服务器可以修改cookie吗,是否可以为您拥有的网站/服务器设置Cookie?