h5页面弹窗滚动穿透的思考
可能我们经常做这样的弹窗对吧,兴许我们绝对很简单,两下搞定:

弹窗的页面结构代码:
<!-- 弹窗模块 引用时移除static_tip类-->
<div class="mask" ontouchstart = "return false" style="display:none"></div>
<div class="main_venue_tip" style="display:none">
<i class="close"></i>
<div class="h_tit">
<i>新用户首单送券活动规则</i>
</div>
<div class="main_v_tcon scroll" id="scroll" style="overflow-y:auto;-webkit-overflow-scrolling:touch;">
<p>(一)活动时间</p>
<p>2015年8月12日9:00:00-8月20日23:59:59</p>
<p>(二)活动限制:</p>
<p>1)参与活动用户须已有绑定微信账号的京东账号;</p>
<p>2)每个京东用户最多可获得2张不同面额的优惠券。不同微信号绑定同一京东账号多次参与活动的,则第一个参与本次活动的账号参与结果有效,其余账号参与结果均视为无效。</p>
<p>(三)参与方式:
用户进入活动页点击“用钱砸”,完成转发好友和分享朋友圈的操作,即可有机会获得面额不等的优惠券。</p>
<p>(四)活动奖券:</p>
<p>1)奖品内容:本次活动以7元到77元不等面额优惠券组成,奖品数量有限,先到先</p>
<p>1)奖品内容:本次活动以7元到77元不等面额优惠券组成,奖品数量有限,先到先</p>
<p>1)奖品内容:本次活动以7元到77元不等面额优惠券组成,奖品数量有限,先到先</p>
<p>1)奖品内容:本次活动以7元到77元不等面额优惠券组成,奖品数量有限,先到先</p>
<p>1)奖品内容:本次活动以7元到77元不等面额优惠券组成,奖品数量有限,先到先</p>
<p>1)奖品内容:本次活动以7元到77元不等面额优惠券组成,奖品数量有限,先到先</p>
<p>1)奖品内容:本次活动以7元到77元不等面额优惠券组成,奖品数量有限,先到先</p>
</div>
</div>
但是产品妹子要求,不能穿透底部滑动,那就bug了
其实做为码奴的我,感觉效果不是蛮好的吗,只是内部滑动,滑到顶部,或滑到底部的时候,会出现穿透底部的滚动条。
为了让产品那边通过,鉴于这个问题,我思考了两种办法。
第一种,简单粗暴,这个内容滑动过程都交由js事件来完成(类似用iscroll.js实现滚动),那我们的最后效果将是下图

内容里面变的没有滚动条,弹窗模块touchmove的时候e.preventDefault(),通过脚本滑动,代码如下(其实就是自己写个与iscroll类似的单一功能插件,苦逼吧,做码奴就是这样折腾人),还是上干货,就是这样:
~function(window,undefined){
prefix= function(){
var _elementStyle = document.createElement('div').style;
var vendors = ['msT','MozT', 'webkitT', 't'],
transform,
i = 0,
l = vendors.length;
for ( ; i < l; i++ ) {
transform = vendors[i] + 'ransform';
if ( transform in _elementStyle ) return vendors[i].substr(0, vendors[i].length-1);
}
return false;
} ();
function Scroll(opts){
this.scrollElem = opts.scrollElem,
this.scrollCon = opts.scrollCon,
this.scrollwp = opts.scrollwp,
this.CH = opts.scrollCon.offsetHeight - opts.scrollwp.offsetHeight,
this.moveDis = 0,
this.touchbool = false;
this.init();
}
Scroll.prototype = {
constructor:"Scroll",
tweenmove:function(dis){
var self = this;
self.scrollCon.style.cssText = "-"+prefix+"-transform:translateY("+dis+"px) translateZ(0);-"+prefix+"-transition:-"+prefix+"-transform 0.2s linear";
},
move:function(dis){
var self = this;
self.scrollCon.style.cssText = "-"+prefix+"-transform:translateY("+dis+"px) translateZ(0)";
},
init:function(){
var _this = this,moveY,touchY;
_this.scrollElem.addEventListener("touchstart",function(e){
var e = e || window.event,
touch=e.touches[0];
e.preventDefault();
touchY = touch.pageY;
_this.touchbool = true;
if(e.target.className.replace(/^\s$/g,"") == "close"){
tip.style.display = "none";
mask.style.display = "none";
}
},false);
_this.scrollElem.addEventListener("touchmove",function(e){
var e = e || window.event;
e.preventDefault();
if(_this.touchbool){
var touch=e.touches[0];
moveY = touch.pageY;
if(moveY-touchY+_this.moveDis < 20 && moveY-touchY+_this.moveDis >(-_this.CH-20) ){
_this.move(moveY-touchY+_this.moveDis);
}
}
},false);
_this.scrollElem.addEventListener("touchend",function(e){
_this.moveDis = moveY-touchY+_this.moveDis;
if(_this.moveDis>=0){
_this.tweenmove(0);
_this.moveDis = 0;
}else if(_this.moveDis <= -_this.CH){
_this.tweenmove(-_this.CH);
_this.moveDis = -_this.CH;
}
_this.touchbool = false;
},false);
}
}
window.Scroll = Scroll;
var tipa = document.getElementById("tipa"),
close = document.querySelector(".close"),
tip = document.querySelector(".main_venue_tip"),
scrollwp = document.querySelector(".main_v_tcon"),
scrollCon = document.querySelector(".scroll_con"),
mask = document.querySelector(".mask");
var scroll = new Scroll({
scrollElem : tip,
scrollwp : scrollwp,
scrollCon : scrollCon
})
tipa.addEventListener("click",function(){
tip.style.display = "block";
mask.style.display = "block";
scroll.CH = scrollCon.offsetHeight - scrollwp.offsetHeight;
},false);
}(window)
第二种,优雅一点,当弹窗显示的时候,让根元素html的高度变成height:100%,overflow:hidden,这样确实解决了弹窗滑动底部不穿透的问题(不要给body height:100%)
不多说,上干货
~function(window,undefined){
var tipa = document.getElementById("tipa"),
close = document.querySelector(".close"),
tip = document.querySelector(".main_venue_tip"),
scrollwp = document.querySelector(".main_v_tcon"),
scrollCon = document.querySelector(".scroll_con"),
mask = document.querySelector(".mask"),scrollTop;
tipa.addEventListener("click",function(){
tip.style.display = "block";
mask.style.display = "block";
//弹出的时候记录值
scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
document.documentElement.style.cssText="height:100%;overflow:hidden;position: relative;";
document.querySelector(".main_bg").style.cssText = "100%;overflow:hidden"
},false);
close.addEventListener("click",function(){
document.body.removeAttribute("style");
document.querySelector(".main_bg").removeAttribute("style");
//隐藏弹窗是,让滚动条滚动到记录的值
document.documentElement.scrollTop = document.body.scrollTop = scrollTop;
tip.style.display = "none";
mask.style.display = "none";
},false)
}(window)
最后要注意的是,第二种方案在手q的项目表现很差,uc,微信效果ok(andriod2.3不支持内部滚动啊注意)。
记录遇到的点滴问题,欢迎拍砖,讨论!
参考资料:
h5页面弹窗滚动穿透的思考的更多相关文章
- 完美解决移动端H5页面的滑动穿透问题
同事的分享,记录下来. 代码如下: css: body.modal-open { position: fixed; width: 100%; } js: // 兼容低版本 document.scrol ...
- 3分钟学会sessionStorage用法(h5页面返回滚动到上次浏览器位置)
前言: 因最近移动端开发过程中遇到一个运营提出的所谓技术难点需求,对于原生APP来说轻而易举,毕竟自己的APP用户操作指哪打哪,但是H5该怎么做?H5就实现不了么?对于一个爱研究攻克这些前端棘手问题的 ...
- h5页面列表滚动加载数据
h5列表滚动加载数据很常见,以下分享下今天做的案例: 前言 这个效果实现需要知道三个参数 1. scrollTop -- 滚动条距离顶部的高度 2. scrollHeight -- 当前页面的总高度( ...
- h5页面弹窗时页面固定(弹窗下面的页面不滑动)
页面出现弹窗时,底部页面不能随之滑动怎么解决? 只需将页面的body增加一个样式 overflow:hidden;就能解决 jq: //开启弹窗 $('body').attr('style','ove ...
- 跳出弹窗页面禁止滚动(PC端和手机端)
pc端如何实现 1.当弹窗显示时,为body元素添加属性:overflow:hidden, 当关闭弹窗时移除该属性即可2.在弹窗的div上设置 @scroll.stop.prevent 3.前端页面弹 ...
- 移动端H5滚动穿透解决方案
最近遇到一个很 巨恶心的问题 ios10下面 页面弹窗有滚动穿透问题 各种google 终于找到了答案,但是体验还不是很好,基本能忍受 废话不多说,上方法 最后终于想到一个处理方案,就是第一种方案的 ...
- vue-蒙层弹窗里的内容滚动。外层大页面禁止滚动
此需求 有两种方法,第一种,这种方法适用于,底层 和弹窗是两个平行的没有关系的两部分.重叠(https://blog.csdn.net/yuhk231/article/details/741717 ...
- h5之scrollIntoView控制页面元素滚动
如果滚动页面也是DOM没有解决的一个问题.为了解决这个问题,浏览器实现了一下方法,以方便开发人员如何更好的控制页面的滚动.在各种专有方法中,HTML5选择了scrollIntoView()作为标准方法 ...
- 微信小程序(6)--获取屏幕宽度及弹窗滚动与页面滚动冲突
1.获取屏幕宽度,并赋值给view <view class="ships-img" style="height:{{windowWidth}}px;"&g ...
随机推荐
- [转]python的requests发送/上传多个文件
1.需要的环境 Python2.X Requests 库 2.单字段发送单个文件 在requests中发送文件的接口只有一种,那就是使用requests.post的files参数, 请求形式如下: ...
- datatable编辑一行数据的方法
let d =t.row($(e).parents("tr")).data(); 上面的是获取一行数据的方法,如果是更改一行数据,则传入根之前数据结构相同的对象或者数组即可: t. ...
- C#------如何使用Swagger调试接口
1.打开NuGet程序包 2.安装下面两个程序包 3.安装完后会出现SwaggerConfig.cs类,并修改里面的内容 代码: [assembly: PreApplicationStartMetho ...
- Ubuntu 16.04服务器 配置
1. 修改用户名称:切换到root打开如下两个配置文件 sudo vim /etc/passwd 把我想改的"xxx"这个用户名改为"way"了,保存并退出 s ...
- 8 -- 深入使用Spring -- 7...4 使用自动装配
8.7.4 使用自动装配 在自动装配策略下,Action还是由Spring插件创建,Spring 插件在创建Action实例时,利用Spring的自动装配策略,将对应的业务逻辑组件注入Action实例 ...
- MySQL开发面试题
……继上一篇MySQL的开发总结之后,适当的练习还是很有必要的…… SQL语法多变,不敢保证唯一,也不敢保证全对,如果错误欢迎指出,即刻修改. 一.现有表结构如下图 TABLENAME:afinfo ...
- windows命令行下用netsh实现端口转发(端口映射)
微软Windows的netsh是一个命令行脚本实用工具.使用netsh工具 ,可以查看或更改本地计算机或远程计算机的网络配置.不仅可以在本地计算机上运行这些命令,而且可以在网络上的远程计算机上运行. ...
- Window日志分析
0X00 简介 0x01 基本设置 A.Windows审核策略设置 前提:开启审核策略,若日后系统出现故障.安全事故则可以查看系统的日志文件,排除故障,追查入侵者的信息等. 打开设置窗口 Window ...
- 查找被占用的端口的服务并kill掉
转自:http://blog.csdn.net/gsls200808/article/details/52456136 方法: C:\>netstat -ano|findstr 8000 TCP ...
- Splash images_enabled 属性
images_enabled属性用于设置加载页面时是否加载图片,如下,禁止之后,返回的页面截图就不会带有任何图片,加载速度也会快很多 function main(splash, args) splas ...