JS弹出层遮罩,隐藏背景页面滚动条细节优化分析


Posted in Javascript onApril 29, 2016

一、去除滚动条方法

给body添加overflow:hidden属性即可,IE6、7下不会生效,需要给html增加overflow:hidden属性

样式中需要对IE6、7及其它浏览器用hack辨别,这是因为当页面拉到下面时如果html或body被overflow:hidden,透明弹层下面的页面就会被部分正常隐藏,通过透明看到的一片的灰度,具体颜色跟平台及用户设置背景色有关。

body或html去掉滚动条后,页面会有一个滚动条宽度/2的跳动!这个跳动对用户体验来十分不好,因此给body添加一下右padding,大小为滚动条的宽度。windows平台下滚动条的宽度为17px,linux平台下不同滚动器滚动条宽度不一致,可以用相关代码计算出滚动条的宽度,以下以windows平台为例。

相关代码:

document.documentElement.style.cssText = ‘overflow:none;+overflow:hidden;_overflow:hidden;';
document.body.style.cssText = ‘overflow:hidden;+overflow:none;_overflow:none;padding:0 17px 0 0;';

以上代码不考虑html或body是否有内联样式 ,如果html或body有内联样式则需要累加,否则会清空原有样式。

二、去除隐患其它方法滚动页面(防止误操作)

隐藏滚动条后,用鼠标滚轮滚动页面确实不会动了,以为这就ok了,不是…

键盘快捷键也可以操作浏览器的一些操作,与滚动页面相关的,比如:上下按键、翻页按键等。针对键盘快捷键,需要取消他们的默认操作。

三、添加弹出层样式

给body添加全局样式(兼容IE6)

height:100%;

给弹层添加滚动样式

overflow-y: auto;
width: 100%;
height: 100%;
left:0;
_padding:0 17px 0 0;   //IE6bug,子元素绝对定位后对于父元素的padding依然有效

以上这篇JS弹出层遮罩,隐藏背景页面滚动条细节优化分析就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于jquery的3d效果实现代码
Mar 23 Javascript
Jquery弹出窗口插件 LeanModal的使用方法
Mar 10 Javascript
一个简单的弹性返回顶部JS代码实现介绍
Jun 09 Javascript
一个CSS+jQuery实现的放大缩小动画效果
Feb 19 Javascript
jQuery无刷新切换主题皮肤实例讲解
Oct 21 Javascript
JS去除字符串中空格的方法
Feb 14 Javascript
详解node+express+ejs+bootstrap构建项目
Sep 27 Javascript
微信小程序网络封装(简单高效)
Aug 06 Javascript
D3.js(v3)+react 实现带坐标与比例尺的散点图 (V3版本)
May 09 Javascript
Node.js+ELK日志规范的实现
May 23 Javascript
微信小程序日历插件代码实例
Dec 04 Javascript
Vue发布订阅模式实现过程图解
Apr 30 Javascript
老生常谈遮罩层 滚动条的问题
Apr 29 #Javascript
弹出遮罩层后禁止滚动效果【实现代码】
Apr 29 #Javascript
一系列Bootstrap导航条使用方法分享
Apr 29 #Javascript
Bootstrap实现下拉菜单效果
Apr 29 #Javascript
Easyui Treegrid改变默认图标的方法
Apr 29 #Javascript
Jquery EasyUI实现treegrid上显示checkbox并取选定值的方法
Apr 29 #Javascript
JS组件Bootstrap导航条使用方法详解
Apr 29 #Javascript
You might like
将数字格式的计算结果转为汉字格式
2006/10/09 PHP
mysq GBKl乱码
2006/11/28 PHP
PHP 加密/解密函数 dencrypt(动态密文,带压缩功能,支持中文)
2009/01/30 PHP
无法在发生错误时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装最快的解决办法
2010/08/01 PHP
PHP学习之输出字符串(echo,print,printf,print_r和var_dump)
2011/04/17 PHP
PHP和JAVA中的重载(overload)和覆盖(override) 介绍
2012/03/01 PHP
PHP判断远程图片或文件是否存在的实现代码
2014/02/20 PHP
利用js跨页面保存变量做菜单的方法
2008/01/17 Javascript
从零开始学习jQuery (二) 万能的选择器
2010/10/01 Javascript
JQuery操作三大控件(下拉,单选,复选)的方法
2013/08/06 Javascript
javascript删除数组元素并且数组长度减小的简单实例
2014/02/14 Javascript
JS的get和set使用示例
2014/02/20 Javascript
jquery操作复选框checkbox的方法汇总
2015/02/05 Javascript
JavaScript使用Math.Min返回两个数中较小数的方法
2015/04/06 Javascript
基于JavaScript实现智能右键菜单
2016/03/02 Javascript
web前端开发upload上传头像js示例代码
2016/10/22 Javascript
jquery easyui如何实现格式化列
2017/07/30 jQuery
[47:03]完美世界DOTA2联赛PWL S3 Galaxy Racer vs Phoenix 第二场 12.10
2020/12/13 DOTA
Python实现二叉搜索树
2016/02/03 Python
Python格式化输出%s和%d
2018/05/07 Python
Python线性拟合实现函数与用法示例
2018/12/13 Python
python 多线程对post请求服务器测试并发的方法
2019/06/13 Python
python rsa实现数据加密和解密、签名加密和验签功能
2019/09/18 Python
10 套华丽的CSS3 按钮小结
2012/10/03 HTML / CSS
全面解析HTML5中的标准属性与自定义属性
2016/02/18 HTML / CSS
英国最受信任的在线眼镜商之一:Fashion Eyewear
2019/10/31 全球购物
WEB控件及HTML服务端控件能否调用客户端方法?如果能,请解释如何调用?
2015/08/25 面试题
毕业生自我鉴定
2013/12/04 职场文书
工作疏忽检讨书
2014/01/25 职场文书
关于青春的演讲稿800字
2014/08/22 职场文书
离婚起诉书范本
2015/05/18 职场文书
苦儿流浪记读书笔记
2015/07/01 职场文书
2019年感恩励志演讲稿(收藏备用)
2019/09/11 职场文书
Unity连接MySQL并读取表格数据的实现代码
2021/06/20 MySQL
3050和2060哪个好 性能差多少 差距有多大 谁更有性价比
2022/06/17 数码科技
python manim实现排序算法动画示例
2022/08/14 Python