javascript div 遮罩层封锁整个页面


Posted in Javascript onJuly 10, 2009

具体解决方案如下:
一、IE和FF下document.body对象的clientHeight,offsetHeight,scrollHeight属性的差别。
clientHeight
在IE和FF下,该属性没什么差别,都是指浏览器的可视区域,即除去浏览器的那些工具栏状态栏剩下的页面展示空间的高度。
offsetHeight
在IE下,offsetHeight也是浏览器可视区域的高(包括边线)
在FF下,offsetHeight是页面具体内容的高度
scrollHeight
在IE下,scrollHeight 是页面具体内容的高度,可以小于clientHeight
在FF下,scrollHeight 是网页内容高度,不过最小值是clientHeight
二、下面是跨浏览器取得当前页面的高度的解决方法。

function getPageSize() 
{ 
var body = document.documentElement; 
var bodyOffsetWidth = 0; 
var bodyOffsetHeight = 0; 
var bodyScrollWidth = 0; 
var bodyScrollHeight = 0; 
var pageDimensions = [0,0]; 
pageDimensions[0]=body.clientHeight; 
pageDimensions[1]=body.clientWidth; 
bodyOffsetWidth=body.offsetWidth; 
bodyOffsetHeight=body.offsetHeight; 
bodyScrollWidth=body.scrollWidth; 
bodyScrollHeight=body.scrollHeight; 
if(bodyOffsetHeight > pageDimensions[0]) 
{ 
pageDimensions[0]=bodyOffsetHeight; 
} 
if(bodyOffsetWidth > pageDimensions[1]) 
{ 
pageDimensions[1]=bodyOffsetWidth; 
} 
if(bodyScrollHeight > pageDimensions[0]) 
{ 
pageDimensions[0]=bodyScrollHeight; 
} 
if(bodyScrollWidth > pageDimensions[1]) 
{ 
pageDimensions[1]=bodyScrollWidth; 
} 
return pageDimensions; 
}

三、页面上必须放置一个div,作为遮罩层,下面是这个遮罩层的css样式。
.lockDiv 
{ 
position:absolute; 
left:0; 
top:0; 
height:0; 
width:0; 
border:2 solid red; 
display:none; 
text-align:center; 
background-color:#DBDBDB; 
filter:Alpha(opacity=60); 
}

四、在客户端使用下面的javascript用遮罩层将整个页面封闭。
var sandglassSpan = 1; 
var timeHdl; 
function DisablePage() 
{ 
var ctrlSandglass = document.getElementById("divSandglass"); 
if(sandglassSpan==0) 
{ 
window.clearTimeout(timeHdl); 
ctrlSandglass.style.display = "none"; 
document.body.style.cursor = 'auto'; 
sandglassSpan = 1; 
} 
else 
{ 
document.body.style.cursor = 'wait'; 
var pageDimensions = getPageSize(); 
ctrlSandglass.style.top = 0; 
ctrlSandglass.style.left = 0; 
ctrlSandglass.style.height = pageDimensions[0]; 
ctrlSandglass.style.width = pageDimensions[1]; 
ctrlSandglass.style.display = "block"; 
timeHdl = window.setTimeout(DisablePage,200); 
} 
}

五、如果页面上使用了ASP.net的Validator控件,那么应该使用如下的javascript。
var sandglassSpan = 1; 
var timeHdl; 
function DisablePageHaveValidator() 
{ 
var ctrlSandglass = document.getElementById("divSandglass"); 
if(false == Page_IsValid) 
{ 
sandglassSpan = 0; 
} 
if(sandglassSpan==0) 
{ 
window.clearTimeout(timeHdl); 
ctrlSandglass.style.display = "none"; 
document.body.style.cursor = 'auto'; 
sandglassSpan = 1; 
} 
else 
{ 
document.body.style.cursor = 'wait'; 
ctrlSandglass.style.display = "block"; 
var pageDimensions = getPageSize(); 
ctrlSandglass.style.top = 0; 
ctrlSandglass.style.left = 0; 
ctrlSandglass.style.height = pageDimensions[0]; 
ctrlSandglass.style.width = pageDimensions[1]; 
timeHdl = window.setTimeout(DisablePageHaveValidator, 200); 
} 
}

六、DisablePage和DisablePageHaveValidator这两个方法可以在按钮的onclick事件或其它时机调用。
Javascript 相关文章推荐
JavaScript Cookie 直接浏览网站分网址
Dec 08 Javascript
JavaScript 一道字符串分解的题目
Aug 03 Javascript
jquery 取子节点及当前节点属性值
Jul 25 Javascript
Node.js插件的正确编写方式
Aug 03 Javascript
jQuery+jsp实现省市县三级联动效果(附源码)
Dec 03 Javascript
JS中的eval 为什么加括号
Apr 13 Javascript
React Native中导航组件react-navigation跨tab路由处理详解
Oct 31 Javascript
基于Vuejs的搜索匹配功能实现方法
Mar 03 Javascript
JavaScript实现短暂提示框功能
Apr 04 Javascript
js/jQuery实现全选效果
Jun 17 jQuery
layui表格内放置图片,并点击放大的实例
Sep 10 Javascript
如何在现代JavaScript中编写异步任务
Jan 31 Javascript
JQuery 实现的页面滚动时浮动窗口控件
Jul 10 #Javascript
javascript 读取xml,写入xml 实现代码
Jul 10 #Javascript
jquery 1.3.2 IE8中的一点点的小问题解决方法
Jul 10 #Javascript
jquery Firefox3.5中操作select的问题
Jul 10 #Javascript
jQuery 版本的文本输入框检查器Input Check
Jul 09 #Javascript
window.onload 加载完毕的问题及解决方案(下)
Jul 09 #Javascript
window.onload 加载完毕的问题及解决方案(上)
Jul 09 #Javascript
You might like
SMARTY学习手记
2007/01/04 PHP
用PHPdig打造属于你自己的Google[图文教程]
2007/02/14 PHP
composer.lock文件的作用
2016/02/03 PHP
Yii框架实现邮箱激活的方法【数字签名】
2016/10/18 PHP
浅析PHP数据导出知识点
2018/02/17 PHP
PHP基于递归算法解决兔子生兔子问题
2018/05/11 PHP
PHP析构函数destruct与垃圾回收机制的讲解
2019/03/22 PHP
js实现的网页颜色代码表全集
2007/07/17 Javascript
javascript 45种缓动效果 非常酷
2011/06/28 Javascript
调用HttpHanlder的几种返回方式小结
2013/12/20 Javascript
Javascript数组操作函数总结
2015/02/05 Javascript
JavaScript程序开发之JS代码放置的位置
2016/01/15 Javascript
javascript html5摇一摇功能的实现
2016/04/19 Javascript
Javascript单例模式的介绍和实例
2016/10/08 Javascript
用Nodejs搭建服务器访问html、css、JS等静态资源文件
2017/04/28 NodeJs
es6在react中的应用代码解析
2017/11/08 Javascript
Vue中div contenteditable 的光标定位方法
2018/08/25 Javascript
JS简单数组排序操作示例【sort方法】
2019/05/17 Javascript
微信小程序云开发之使用云存储
2019/05/17 Javascript
详解javascript void(0)
2020/07/13 Javascript
解决vue 使用setTimeout,离开当前路由setTimeout未销毁的问题
2020/07/21 Javascript
Python程序语言快速上手教程
2012/07/18 Python
python多线程扫描端口示例
2014/01/16 Python
python实现linux服务器批量修改密码并生成execl
2014/04/22 Python
Python+微信接口实现运维报警
2016/08/27 Python
python 以16进制打印输出的方法
2018/07/09 Python
Python全排列操作实例分析
2018/07/24 Python
Anaconda3+tensorflow2.0.0+PyCharm安装与环境搭建(图文)
2020/02/18 Python
python开发前景如何
2020/06/11 Python
护士自荐信
2013/10/25 职场文书
夜班门卫岗位职责
2013/12/09 职场文书
能源工程专业应届生求职信
2014/03/01 职场文书
巾帼志愿者活动方案
2014/08/17 职场文书
2014年教师工作总结
2014/11/10 职场文书
2015年五一劳动节活动总结
2015/02/09 职场文书
教你用Python+selenium搭建自动化测试环境
2021/06/18 Python